当前位置:   article > 正文

spring boot + mybatis + druid实现多数据源配置_"@configurationproperties(\"spring.datasource.drui

"@configurationproperties(\"spring.datasource.druid.master\")"

源码:https://download.csdn.net/download/asd792520/11830815

一、结构目录

二、添加主要依赖

自行添加mysql或者oracle驱动包

三、多数据源的处理

1、自定义注解以及数据源枚举

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description 自定义多数据源切换注解
  5. */
  6. @Target({ ElementType.METHOD, ElementType.TYPE})
  7. @Retention(RetentionPolicy.RUNTIME)
  8. @Documented
  9. @Inherited
  10. public @interface DataSource {
  11. public DataSourceType value() default DataSourceType.MASTER;
  12. }
  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description 数据源
  5. */
  6. public enum DataSourceType {
  7. /**
  8. * 主库
  9. */
  10. MASTER,
  11. /**
  12. * 从库
  13. */
  14. SLAVE
  15. }

 

 2、druid配置属性

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description druid 配置属性
  5. */
  6. @Configuration
  7. public class DruidProperties {
  8. @Value("${spring.datasource.druid.initialSize}")
  9. private int initialSize;
  10. @Value("${spring.datasource.druid.minIdle}")
  11. private int minIdle;
  12. @Value("${spring.datasource.druid.maxActive}")
  13. private int maxActive;
  14. @Value("${spring.datasource.druid.maxWait}")
  15. private int maxWait;
  16. @Value("${spring.datasource.druid.timeBetweenEvictionRunsMillis}")
  17. private int timeBetweenEvictionRunsMillis;
  18. @Value("${spring.datasource.druid.minEvictableIdleTimeMillis}")
  19. private int minEvictableIdleTimeMillis;
  20. @Value("${spring.datasource.druid.maxEvictableIdleTimeMillis}")
  21. private int maxEvictableIdleTimeMillis;
  22. @Value("${spring.datasource.druid.validationQuery}")
  23. private String validationQuery;
  24. @Value("${spring.datasource.druid.testWhileIdle}")
  25. private boolean testWhileIdle;
  26. @Value("${spring.datasource.druid.testOnBorrow}")
  27. private boolean testOnBorrow;
  28. @Value("${spring.datasource.druid.testOnReturn}")
  29. private boolean testOnReturn;
  30. public DruidDataSource dataSource(DruidDataSource datasource)
  31. {
  32. /** 配置初始化大小、最小、最大 */
  33. datasource.setInitialSize(initialSize);
  34. datasource.setMaxActive(maxActive);
  35. datasource.setMinIdle(minIdle);
  36. /** 配置获取连接等待超时的时间 */
  37. datasource.setMaxWait(maxWait);
  38. /** 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 */
  39. datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
  40. /** 配置一个连接在池中最小、最大生存的时间,单位是毫秒 */
  41. datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
  42. datasource.setMaxEvictableIdleTimeMillis(maxEvictableIdleTimeMillis);
  43. /**
  44. * 用来检测连接是否有效的sql,要求是一个查询语句,常用select 'x'。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。
  45. */
  46. datasource.setValidationQuery(validationQuery);
  47. /** 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。 */
  48. datasource.setTestWhileIdle(testWhileIdle);
  49. /** 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。 */
  50. datasource.setTestOnBorrow(testOnBorrow);
  51. /** 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。 */
  52. datasource.setTestOnReturn(testOnReturn);
  53. return datasource;
  54. }
  55. }

3、druid 配置多数据源

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description druid 配置多数据源
  5. */
  6. @Configuration
  7. public class DruidConfig {
  8. @Bean
  9. @ConfigurationProperties("spring.datasource.druid.master")
  10. public DataSource masterDataSource(DruidProperties properties) {
  11. DruidDataSource build = DruidDataSourceBuilder.create().build();
  12. return properties.dataSource(build);
  13. }
  14. @Bean
  15. @ConfigurationProperties("spring.datasource.druid.slave")
  16. @ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true")
  17. public DataSource slaveDataSource(DruidProperties properties) {
  18. DruidDataSource build = DruidDataSourceBuilder.create().build();
  19. return properties.dataSource(build);
  20. }
  21. @Bean(name = "dynamicDataSource")
  22. @Primary
  23. public DynamicDataSource dataSource(DataSource masterDataSource, DataSource slaveDataSource)
  24. {
  25. Map<Object, Object> targetDataSources = new HashMap<>();
  26. targetDataSources.put(DataSourceType.MASTER.name(), masterDataSource);
  27. targetDataSources.put(DataSourceType.SLAVE.name(), slaveDataSource);
  28. return new DynamicDataSource(masterDataSource, targetDataSources);
  29. }
  30. }

4、数据源的切换处理

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description 数据源切换处理
  5. */
  6. @Slf4j
  7. public class DynamicDataSourceContextHolder {
  8. /**
  9. * 使用ThreadLocal维护变量,ThreadLoacl为每个使用该变量的线程提供独立变量副本
  10. * 所以每个线程都可以独立的改变自己的副本,而不影响其他线程对应的副本
  11. */
  12. private static final ThreadLocal<String> CONTEXT_HOLDER = new ThreadLocal<>();
  13. /**
  14. * 设置数据源变量
  15. * @param dataSourceType
  16. */
  17. public static void setDataSourceType(String dataSourceType) {
  18. log.info("切换到{}数据源", dataSourceType);
  19. CONTEXT_HOLDER.set(dataSourceType);
  20. }
  21. /**
  22. * 获取数据源变量
  23. */
  24. public static String getDataSourceType() {
  25. return CONTEXT_HOLDER.get();
  26. }
  27. /**
  28. * 清楚数据源变量
  29. */
  30. public static void clearDataSourceType() {
  31. CONTEXT_HOLDER.remove();
  32. }
  33. }

5、动态数据源

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description 动态数据源
  5. */
  6. public class DynamicDataSource extends AbstractRoutingDataSource {
  7. public DynamicDataSource(DataSource defaultTargetDataSource, Map<Object, Object> targetDataSources) {
  8. super.setDefaultTargetDataSource(defaultTargetDataSource);
  9. super.setTargetDataSources(targetDataSources);
  10. super.afterPropertiesSet();
  11. }
  12. @Override
  13. protected Object determineCurrentLookupKey() {
  14. return DynamicDataSourceContextHolder.getDataSourceType();
  15. }
  16. }

 6、利用aop进行多数据源处理

  1. /**
  2. * Created by qiuzhb on 2019/9/30.
  3. *
  4. * @Description 多数据源处理
  5. */
  6. @Aspect
  7. @Order(1)
  8. @Component
  9. @Slf4j
  10. public class DataSourceAcpect {
  11. @Pointcut("@annotation(com.qiuzhb.annotation.DataSource)" +
  12. "|| @within(com.qiuzhb.annotation.DataSource)")
  13. public void dsPoincut() {
  14. }
  15. @Around("dsPoincut()")
  16. public Object around(ProceedingJoinPoint point) throws Throwable {
  17. DataSource dataSource = getDataSource(point);
  18. if (dataSource != null) {
  19. DynamicDataSourceContextHolder.setDataSourceType(dataSource.value().name());
  20. }
  21. try {
  22. return point.proceed();
  23. } finally {
  24. // 销毁数据源,在执行方法之后
  25. DynamicDataSourceContextHolder.clearDataSourceType();
  26. }
  27. }
  28. /**
  29. * 获取需要切换的数据源
  30. * @param joinPoint
  31. * @return
  32. */
  33. public DataSource getDataSource(ProceedingJoinPoint joinPoint) {
  34. MethodSignature signature = (MethodSignature) joinPoint.getSignature();
  35. Class<? extends Object> aClass = joinPoint.getTarget().getClass();
  36. DataSource targetDataSource = aClass.getAnnotation(DataSource.class);
  37. if (targetDataSource != null ) {
  38. return targetDataSource;
  39. } else {
  40. Method method = signature.getMethod();
  41. DataSource methodDataSource = method.getAnnotation(DataSource.class);
  42. return methodDataSource;
  43. }
  44. }
  45. }

四、测试

在service类中的方法上打上注解

  1. @DataSource(DataSourceType.SLAVE)
  2. public int getCount() {
  3. int count = dao.getCount();
  4. return count;
  5. }

 编写test测试

  1. @Test
  2. public void dataSourceTest() {
  3. int count = service.getCount();
  4. System.out.println(count);
  5. }

结果:

ps:如有问题,还望不吝赐教! 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/52416
推荐阅读
相关标签
  

闽ICP备14008679号