zoukankan      html  css  js  c++  java
  • springboot 多数据源配置

    1、配置类

    import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
    import org.springframework.boot.context.properties.ConfigurationProperties;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Primary;
    
    import javax.sql.DataSource;
    import java.util.HashMap;
    import java.util.Map;
    
    /**
     * 配置多数据源
     */
    @Configuration
    public class DynamicDataSourceConfig {
    
      @Bean
      @ConfigurationProperties("spring.datasource.druid.report")
      public DataSource reportDataSource() {
        return DruidDataSourceBuilder.create().build();
      }
      
      @Bean
      @ConfigurationProperties("spring.datasource.druid.etlengine-v4")
      public DataSource etlengineV4DataSource() {
          return DruidDataSourceBuilder.create().build();
      }
      
    
      @Bean
      @Primary
      public DynamicDataSource dataSource(DataSource reportDataSource, DataSource etlengineV4DataSource) {
        Map<Object, Object> targetDataSources = new HashMap<>();
        targetDataSources.put(DataSourceNames.REPORT, reportDataSource);
        targetDataSources.put(DataSourceNames.ETLENGINE_V4, etlengineV4DataSource);
        return new DynamicDataSource(reportDataSource, targetDataSources);
      }
    }

    2、动态数据源

    import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
    
    import javax.sql.DataSource;
    import java.util.Map;
    
    /**
     * 动态数据源
     */
    public class DynamicDataSource extends AbstractRoutingDataSource {
      private static final ThreadLocal<String> contextHolder = new ThreadLocal<>();
    
      public DynamicDataSource(DataSource defaultTargetDataSource,
          Map<Object, Object> targetDataSources) {
        super.setDefaultTargetDataSource(defaultTargetDataSource);
        super.setTargetDataSources(targetDataSources);
        super.afterPropertiesSet();
      }
    
      @Override
      protected Object determineCurrentLookupKey() {
        return getDataSource();
      }
    
      public static void setDataSource(String dataSource) {
        contextHolder.set(dataSource);
      }
    
      public static String getDataSource() {
        return contextHolder.get();
      }
    
      public static void clearDataSource() {
        contextHolder.remove();
      }
    
    }

    3、自定义一个注解,并通过aop自定义切面去动态注入不同的数据源

    @Target({ElementType.TYPE, ElementType.METHOD})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    public @interface DataSource {
      String name() default "";
    }
    @Aspect
    @Component
    public class DataSourceAspect implements PriorityOrdered {
      protected Logger logger = LoggerFactory.getLogger(getClass());
    
      @Pointcut("@annotation(com.patrick.datasources.annotation.DataSource)")
      public void dataSourcePointCut() {
    
      }
    
      @Around("dataSourcePointCut()")
      public Object around(ProceedingJoinPoint point) throws Throwable {
        MethodSignature signature = (MethodSignature) point.getSignature();
        Method method = signature.getMethod();
    
        DataSource ds = method.getAnnotation(DataSource.class);
        if (ds == null) {
          DynamicDataSource.setDataSource(DataSourceNames.REPORT);
          logger.debug("set datasource is " + DataSourceNames.REPORT);
        } else {
          DynamicDataSource.setDataSource(ds.name());
          logger.debug("set datasource is " + ds.name());
        }
    
        try {
          return point.proceed();
        } finally {
          DynamicDataSource.clearDataSource();
          logger.debug("clean datasource");
        }
      }
    
      @Override
      public int getOrder() {
        return 1;
      }
    }
  • 相关阅读:
    pandas 移动列的方法
    D-Link 路由器新漏洞,黑客可远程执行任意命令
    世界第一黑客:未来云安全的威胁
    黑客针对参与Covid-19疫苗分发的公司
    iPhone为盲人自动识别并标记按钮和UI功能
    小心!基于UEFI引导的病毒,重装系统也清除不了
    美国禁用面部识别技术,到底是什么原因?
    Apple的双向无线充电器现已上市,预计最快在本周发货
    警惕黑客通过打印机侵入你的系统
    为什么未来没有密码?黑客还能破解吗?网友:同样危险
  • 原文地址:https://www.cnblogs.com/patrick-king/p/12098401.html
Copyright © 2011-2022 走看看