项目场景:
最近接到一个需求,大概意思呢就是数据库连接不够用了,部分服务(分服务)就不需要配置数据源了,需要跟db打交道的地方全部改成rpc去调用具备db能力的服务(总服务)
问题描述:
其实需要改的地方并不多,分服务实际上也就只有几个接口会被调用到,主要是插入操作,写一个rpc接口即可。至于排除数据源,毕竟一直都是配了数据源的,突然不配了还有点不知所措。这里就有点小坑,后面会提到。
解决方案:
1.业务逻辑
调用数据库的部分,全部改成一个接口,具体走的实现逻辑,可以通过配置文件来决定。
public interface UploadRecordDbOrRpcService {
Integer insert(Object object);
Integer updateById(Object object);
Integer deleteById(Serializable id);
}
对应的实现类呢,会有两个一个是db的实现类,一个是rpc实现类
db实现类
public class UploadRecordDbServiceImpl implements UploadRecordDbOrRpcService {
public Integer insert(Object object){
}
public Integer updateById(Object object){
}
public Integer deleteById(Serializable id){
}
}
rpc实现类
public class UploadRecordRPCServiceImpl implements UploadRecordDbOrRpcService {
public Integer insert(Object object){
}
public Integer updateById(Object object){
}
public Integer deleteById(Serializable id){
}
}
实现类定义完成后,我们还需要一个配置文件来决定最后走的是哪一个逻辑(实现类)(注意以上的两个实现类不要注入到容器中,需要我们自己配置)
配置类:
@Configuration
@Slf4j
public class UploadBeanConfig {
@Value("${isDB:false}")
private boolean isDB;
@Bean
public UploadRecordDbOrRpcService uploadRecordDbOrRpcService(){
if (isDB) {
log.info("use db");
return new UploadRecordDbServiceImpl();
} else {
log.info("use rpc");
return new UploadRecordRpcServiceImpl();
}
}
}
我们只需要配置一下yml文件
isDB: true #表示当前服务具备db能力 false表示当前不具备db,走rpc接口
2.排除数据源
思路:
1.去除springboot相应的自动配置类 DataSourceAutoConfiguration
2.动态配置mapperScan注解
1.springboot的一大特性就是自动配置,默认情况下web工程都是需要配置数据源的。如果想要排除数据源,可以通过以下几种方式
- @EnableAutoConfiguration/SpringBootApplication注解有一个属性exclude它可以帮助我们排除指定的自动配置类
@EnableAutoConfiguration(exclude = DataSourceAutoConfiguration.class)
public class xxxConfig {}
- 通过配置文件进行排除
spring:
autoconfigure:
exclude:
- org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
2.对于mapperScan注解我们可以专门写一个配置类,通过springboot的自动配置方式将其注入,最后再exclude出去。也可以使用两个配置类配合@Condition系类的注解达到这个效果。
MapperPlusConfiguration配置类
@MapperScan("com.juphoon.iron.mapper")
@Configuration
public class MapperPlusConfigure {
}
创建spring.factories
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.xx.xx.config.MapperPlusConfigure
至此,mapperScan的功能也自动配置了进去。
如果不配置数据源的话只需要通过修改application.yml文件
spring:
autoconfigure:
exclude:
- org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
- com.xx.xx.config.MapperPlusConfigure