时间:2021-07-01 10:21:17 帮助过:36人阅读
DateSource 定义注解
DateSourceContext 定义ThreadLocal上下文
DataSourceRouteAspect会拦截注解dataSource的方法,业务方法之前设置数据源,设置到ThreadLocal中
也可根据业务参数自主设置数据源,达到分库效果
DruidConfig 配置多数据源
MybatisConfig 扫描sql配置类
RouteDataSource 通过继承AbstractRoutingDataSource重写,获取ThreadLocal中的数据源
@Target({ ElementType.METHOD,ElementType.TYPE,ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface DataSource {
String value() default "";
}
public class DataSourceContext {
private static final ThreadLocal<String> context = new ThreadLocal<>();
public static void setDataSource(String value){
context.set(value);
}
public static String getDataSource(){
return context.get();
}
public static void clearDataSource(){
context.remove();
}
}
@Aspect
@Component
public class DataSourceRouteAspect {
@Before("@annotation(dataSource)")
public void selectDateSource(JoinPoint point, DataSource dataSource){
String value = dataSource.value();
DataSourceContext.setDataSource(value);
}
@After("@annotation(dataSource)")
public void removeDataSource(JoinPoint point, DataSource dataSource){
DataSourceContext.clearDataSource();
}
}
@Configuration
public class DruidConfig {
// @Value("${mysql.one.aliasName}")
// private String aliasNameOne;
// @Primary
@Bean(name="dataSourceOne",initMethod = "init",destroyMethod = "close")
@ConfigurationProperties(prefix = "mysql.one")
public DruidDataSource dataSourceOne(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setQueryTimeout(300);
dataSource.setTestWhileIdle(true);
dataSource.setTestOnBorrow(true);
dataSource.setTestOnReturn(true);
dataSource.setTimeBetweenEvictionRunsMillis(600000);
dataSource.setMinEvictableIdleTimeMillis(300000);
return dataSource;
}
// @Bean(name="dataSourceTwo",initMethod = "init",destroyMethod = "close")
// @ConfigurationProperties(prefix = "mysql.two")
// public DruidDataSource dataSourceOne(){
// return dataSource;
// }
@Bean(name = "routeDataSource")
public RouteDataSource dataSource(@Qualifier("dataSourceOne")DruidDataSource dataSourceOne
// ,@Qualifier("dataSourceTwo")DruidDataSource dataSourceTwo
){
Map<Object, Object> targetDataSources = new HashMap<>();
targetDataSources.put("dataSourceOne",dataSourceOne);
// targetDataSources.put("dataSourceTwo",dataSourceTwo);
RouteDataSource dataSource = new RouteDataSource();
dataSource.setTargetDataSources(targetDataSources);
dataSource.setDefaultTargetDataSource(dataSourceOne);
System.out.println("routeDataSource******************"+dataSource);
return dataSource;
}
}
@Configuration
public class DruidConfig {
// @Value("${mysql.one.aliasName}")
// private String aliasNameOne;
// @Primary
@Bean(name="dataSourceOne",initMethod = "init",destroyMethod = "close")
@ConfigurationProperties(prefix = "mysql.one")
public DruidDataSource dataSourceOne(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setQueryTimeout(300);
dataSource.setTestWhileIdle(true);
dataSource.setTestOnBorrow(true);
dataSource.setTestOnReturn(true);
dataSource.setTimeBetweenEvictionRunsMillis(600000);
dataSource.setMinEvictableIdleTimeMillis(300000);
return dataSource;
}
// @Bean(name="dataSourceTwo",initMethod = "init",destroyMethod = "close")
// @ConfigurationProperties(prefix = "mysql.two")
// public DruidDataSource dataSourceOne(){
// return dataSource;
// }
@Bean(name = "routeDataSource")
public RouteDataSource dataSource(@Qualifier("dataSourceOne")DruidDataSource dataSourceOne
// ,@Qualifier("dataSourceTwo")DruidDataSource dataSourceTwo
){
Map<Object, Object> targetDataSources = new HashMap<>();
targetDataSources.put("dataSourceOne",dataSourceOne);
// targetDataSources.put("dataSourceTwo",dataSourceTwo);
RouteDataSource dataSource = new RouteDataSource();
dataSource.setTargetDataSources(targetDataSources);
dataSource.setDefaultTargetDataSource(dataSourceOne);
System.out.println("routeDataSource******************"+dataSource);
return dataSource;
}
}
public class RouteDataSource extends AbstractRoutingDataSource {
@Override
protected Object determineCurrentLookupKey() {
return DataSourceContext.getDataSource();
}
}
mapper配置类
import cn.com.config.dbConfig.DataSource;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
@Mapper
public interface MyTestIbatis extends BaseMapper<String>{
@DataSource("dataSourceOne")
@Select("select id from tbl_user")
List<String> selectStr();
}
import tk.mybatis.mapper.common.Mapper;
public interface BaseMapper<T> extends Mapper<T> {
}
@Autowired
MyTestIbatis myTestIbatis;
myTestIbatis.selectStr()
springboot&数据库连接池&切面动态数据源
标签:aspect oid amp app auto cer table java nec