项目场景:

最近接到一个需求,大概意思呢就是数据库连接不够用了,部分服务(分服务)就不需要配置数据源了,需要跟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