继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

springboot配置多数据源

安卓软件程序开发入门学习
关注TA
已关注
手记 289
粉丝 49
获赞 282

在做项目的过程中难免会遇到这种情况:一个项目需要两个数据库中的数据,希望这篇文章能给遇到这些问题的小伙伴一点帮助

第一步:将两个数据源的mapper接口和xml文件分别放入不同的文件夹下;

第二步:在application.yml文件中加入双数据源,一定要指定主数据源,不然会报错

spring:  datasource:    primary:      driver-class-name: com.mysql.jdbc.Driver      url: url地址      username: 用户名      password: 密码    secondary:      driver-class-name: com.mysql.jdbc.Driver      url: url地址      username: 用户名      password: 密码

第三步:config类:

@Configuration@MapperScan(basePackages = "数据源1的mapper路径:com.dao.mapper.interface1", sqlSessionTemplateRef  = "test1SqlSessionTemplate")public class DataSource1Config {    @Bean(name = "test1DataSource")    @ConfigurationProperties(prefix = "spring.datasource.primary")    @Primary    public DataSource testDataSource() {        return DataSourceBuilder.create().build();    }    @Bean(name = "test1SqlSessionFactory")    @Primary    public SqlSessionFactory testSqlSessionFactory(@Qualifier("test1DataSource") DataSource dataSource) throws Exception {        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();        bean.setDataSource(dataSource);        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis/mapper/数据源1/*.xml"));//指定mapper.xml路径        return bean.getObject();    }    @Bean(name = "test1TransactionManager")    @Primary    public DataSourceTransactionManager testTransactionManager(@Qualifier("test1DataSource") DataSource dataSource) {        return new DataSourceTransactionManager(dataSource);    }    @Bean(name = "test1SqlSessionTemplate")    @Primary    public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("test1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {        return new SqlSessionTemplate(sqlSessionFactory);    }}
@Configuration@MapperScan(basePackages = "数据源2的mapper路径:com.dao.mapper.interface2", sqlSessionTemplateRef  = "test2SqlSessionTemplate")public class DataSource2Config {    @Bean(name = "test2DataSource")    @ConfigurationProperties(prefix = "spring.datasource.secondary")    public DataSource testDataSource() {        return DataSourceBuilder.create().build();    }    @Bean(name = "test2SqlSessionFactory")    public SqlSessionFactory testSqlSessionFactory(@Qualifier("test2DataSource") DataSource dataSource) throws Exception {        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();        bean.setDataSource(dataSource);        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis/mapper/数据源2/*.xml"));//指定mapper.xml路径        return bean.getObject();    }    @Bean(name = "test2TransactionManager")    public DataSourceTransactionManager testTransactionManager(@Qualifier("test2DataSource") DataSource dataSource) {        return new DataSourceTransactionManager(dataSource);    }    @Bean(name = "test2SqlSessionTemplate")    public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("test2SqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {        return new SqlSessionTemplate(sqlSessionFactory);    }}

此时,项目是可以运行起来的,但是MySql有一个问题,就是配置双数据源后,当连接池空闲时间超过8小时,数据库连接就会自动断掉,为了避免这种情况,还需要在yml文件下加入如下配置:

datasource:    primary:        max-idle: 10        max-wait: 10000        min-idle: 5        initial-size: 5        validation-query: SELECT 1        test-on-borrow: false        test-while-idle: true        time-between-eviction-runs-millis: 18800 #就是这句话    secondary:              max-idle: 10              max-wait: 10000              min-idle: 5              initial-size: 5              validation-query: SELECT 1              test-on-borrow: false              test-while-idle: true              time-between-eviction-runs-millis: 18800 #就是这句话

目前配置双数据源已经完成了。

当然,上面的配置是针对使用默认数据源的配置,但是还有很多童鞋使用了阿里的druid数据源,两种原理基本相同,只是稍作改动:

spring:  datasource:   druid:     primary:      driver-class-name: com.mysql.jdbc.Driver      url: url地址      username: 用户名      password: 密码    secondary:      driver-class-name: com.mysql.jdbc.Driver      url: url地址      username: 用户名      password: 密码

在config中作如下修改:

将 DataSourceBuilder 改为 DuridDataSourceBuilder


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP