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

    原文:https://www.jianshu.com/p/033e0ebeb617

    项目中用到了两个数据库,分别是Oracle和Mysql,涉及到了多数据源问题,这里做下记录
    官方讲解:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter
    日志JDBC配置:https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_LogFilter
    Druid常见问题汇总:https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

    配置

    • 首先配置application.yml文件,这里利用阿里的Druid作为连接池,base和follow分别代表主库和从库
    spring:
      datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        base:
          type: com.alibaba.druid.pool.DruidDataSource
          driver-class-name: oracle.jdbc.driver.OracleDriver
          initialize: true #指定初始化数据源,是否用data.sql来初始化,默认: true
          name: base
          jdbc-url: jdbc:oracle:thin:@189.126.156.396:9522:oratest
          username: 用户名
          password: 密码
        follow:
          type: com.alibaba.druid.pool.DruidDataSource
          driver-class-name: com.mysql.jdbc.Driver
          initialize: true
          name: follow
          url: jdbc:mysql://162.66.66.66:3666/paygateway
          username: 你的歌用户名
          password: 你的密码
    ---
    #下面是分页和日志相关内容,不需要可以删掉
    pagehelper:
      reasonable: true
      helperDialect: oracle
      support-methods-arguments: true
      params: count=countSql
    mybatis:
      configuration:
        mapUnderscoreToCamelCase: true
    
    logging:
      level:
        com:
          xxx:
            paygateway:
              dao: DEBUG
        org:
          spring:
            springboot:
              dao: DEBUG
          springframework: WARN
    
    • 配置主库Configuration,注意prefix前缀和@Primary注解(表示主库)和下划线转驼峰方法的配置
    @Configuration
    @MapperScan(basePackages = "com.xxx.paygateway.dao.db1", sqlSessionTemplateRef = "baseSqlSessionTemplate")
    public class BaseDataSourceConfig {
        //这里配置数据源
        @Bean(name = "baseDataSource")
        @ConfigurationProperties(prefix = "spring.datasource.base")
        @Primary 
        public DataSource setDataSource() {
            return DataSourceBuilder.create().build();
        }
    
        //这里配置事务管理器
        @Bean(name = "baseTransactionManager")
        @Primary
        public DataSourceTransactionManager setTransactionManager(@Qualifier("baseDataSource") DataSource dataSource) {
            return new DataSourceTransactionManager(dataSource);
        }
    
        //这里配置SqlSessionFactory,连接工厂
        @Bean(name = "baseSqlSessionFactory")
        @Primary
        public SqlSessionFactory setSqlSessionFactory(@Qualifier("baseDataSource") DataSource dataSource) throws Exception {
            SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
            //此处配置下划线转驼峰
            org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
            configuration.setMapUnderscoreToCamelCase(true);
            bean.setConfiguration(configuration);
            bean.setDataSource(dataSource);
            //此处配置mybatis扫描路径
            bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mappers/base/*.xml"));
            return bean.getObject();
        }
    
        //这里配置SqlSessionTemplate,标准操作模板
        @Bean(name = "baseSqlSessionTemplate")
        @Primary
        public SqlSessionTemplate setSqlSessionTemplate(@Qualifier("baseSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
            return new SqlSessionTemplate(sqlSessionFactory);
        }
    }
    
    • 配置从库Configuration,与从库基本一致,注意注解和前缀就可以了
    @Configuration
    @MapperScan(basePackages = "com.xxx.paygateway.dao.db2", sqlSessionTemplateRef = "fSqlSessionTemplate")
    public class FollowDataSourceConfig {
        @Bean(name = "fDataSource")
        @ConfigurationProperties(prefix = "spring.datasource.follow")
        public DataSource setDataSource() {
            return new DruidDataSource();
        }
    
        @Bean(name = "fTransactionManager")
        public DataSourceTransactionManager setTransactionManager(@Qualifier("fDataSource") DataSource dataSource) {
            return new DataSourceTransactionManager(dataSource);
        }
    
        @Bean(name = "fSqlSessionFactory")
        public SqlSessionFactory setSqlSessionFactory(@Qualifier("fDataSource") DataSource dataSource) throws Exception {
            SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
            org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
            configuration.setMapUnderscoreToCamelCase(true);
            bean.setConfiguration(configuration);
            bean.setDataSource(dataSource);
            bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mappers/follow/*.xml"));
            return bean.getObject();
        }
    
        @Bean(name = "fSqlSessionTemplate")
        public SqlSessionTemplate setSqlSessionTemplate(@Qualifier("fSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
            return new SqlSessionTemplate(sqlSessionFactory);
        }
    }
    
    • 把两个数据库的dao层和mapper.xml文件分到不同的文件夹下面,1归1,2归2。service层正常调用即可!


       
      image.png

       
      image.png


    作者:后厂村老司机
    链接:https://www.jianshu.com/p/033e0ebeb617
    來源:简书
    简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
  • 相关阅读:
    AudioStreamer电话打进时崩溃
    ios中NSLog输出格式大全
    IOS Framework制作(一)
    UIButton上的文字添加阴影
    Tim Cook向员工发邮件,祝贺大家实现创纪录的季度
    ios 通讯录“写”操作大全
    AVAudioSession的Category
    IOS播放优酷视频
    iOS 设备的网页调试工具Firebug
    iOS中retain和copy的区别
  • 原文地址:https://www.cnblogs.com/shihaiming/p/9566178.html
Copyright © 2011-2022 走看看