六、springboot(三)配置双数据源
1、目录结构
2.jdbc.properties配置
#db houge spring.datasource.houge.jdbc-url=jdbc:oracle:thin:@192.168.0.120::ORCL spring.datasource.houge.username=houge spring.datasource.houge.password=monkey spring.datasource.houge.driver-class-name=oracle.jdbc.driver.OracleDriver spring.datasource.houge.initial-size= spring.datasource.houge.min-idle= spring.datasource.houge.max-active= #db gkh spring.datasource.gkh.jdbc-url=jdbc:oracle:thin:@192.168.0.115::ORCL spring.datasource.gkh.username=gkh spring.datasource.gkh.password= spring.datasource.gkh.driver-class-name=oracle.jdbc.driver.OracleDriver spring.datasource.gkh.initial-size= spring.datasource.gkh.min-idle= spring.datasource.gkh.max-active=
3、注解式数据源配置DataSourceConfig
@Configuration @PropertySource("classpath:config/jdbc.properties") public class DataSourceConfig { @Primary @Bean(name = "dataSourceHouge") @ConfigurationProperties(prefix = "spring.datasource.houge") public DataSource dataSourceHouge() { return DataSourceBuilder.create().build(); } @Bean(name = "dataSourceGkh") @ConfigurationProperties(prefix = "spring.datasource.gkh") public DataSource dataSourceGkh() { return DataSourceBuilder.create().build(); } }
4、houge数据库配置
@Configuration @EnableTransactionManagement @EnableJpaRepositories( entityManagerFactoryRef = "entityManagerFactoryHouge", transactionManagerRef = "transactionManagerHouge", basePackages = {"com.lofty.springboot.repository.houge" }) public class HougeDataSource { @Autowired @Qualifier("dataSourceHouge") private DataSource dataSourceHouge; @Primary @Bean(name = "entityManagerFactoryHouge") public LocalContainerEntityManagerFactoryBean entityManagerFactoryHouge(EntityManagerFactoryBuilder builder) { LocalContainerEntityManagerFactoryBean em = builder.dataSource(dataSourceHouge) .packages("com.lofty.springboot.domain.houge") .persistenceUnit("hougePersistenceUnit").build(); return em; } @Primary @Bean(name = "transactionManagerHouge") PlatformTransactionManager transactionManagerHouge(EntityManagerFactoryBuilder builder) { return new JpaTransactionManager(entityManagerFactoryHouge(builder).getObject()); } }
5、gkh数据库配置
@Configuration @EnableTransactionManagement @EnableJpaRepositories( entityManagerFactoryRef = "entityManagerFactoryGkh", transactionManagerRef = "transactionManagerGkh", basePackages = {"com.lofty.springboot.repository.gkh" }) public class GkhDataSource { @Autowired @Qualifier("dataSourceGkh") private DataSource dataSourceGkh; @Bean(name = "entityManagerFactoryGkh") public LocalContainerEntityManagerFactoryBean entityManagerFactoryGkh(EntityManagerFactoryBuilder builder) { LocalContainerEntityManagerFactoryBean em = builder.dataSource(dataSourceGkh) .packages("com.lofty.springboot.domain.gkh") .persistenceUnit("gkhPersistenceUnit").build(); return em; } @Bean(name = "transactionManagerGkh") PlatformTransactionManager transactionManagerGkh(EntityManagerFactoryBuilder builder) { return new JpaTransactionManager(entityManagerFactoryGkh(builder).getObject()); } }
6、启动测试
六、springboot(三)配置双数据源的更多相关文章
- spring项目配置双数据源读写分离
我们最早做新项目的时候一直想做数据库的读写分离与主从同步,由于一些原因一直没有去做这个事情,这次我们需要配置双数据源的起因是因为我们做了一个新项目用了另一个数据库,需要把这个数据库的数据显示到原来的后 ...
- spring boot 配置双数据源mysql、sqlServer
背景:原来一直都是使用mysql数据库,在application.properties 中配置数据库信息 spring.datasource.url=jdbc:mysql://xxxx/test sp ...
- SpringBoot+MyBatis配置多数据源
SpringBoot 可以支持多数据源,这是一个非常值得学习的功能,但是从现在主流的微服务的架构模式中,每个应用都具有唯一且准确的功能,多数据源的需求很难用到,考虑到实际情况远远比理论复杂的多,这里还 ...
- spring+mybatis 配置双数据源
配置好后,发现网上已经做好的了, 不过,跟我的稍有不同, 我这里再拿出来现个丑: properties 文件自不必说,关键是这里的xml: <?xml version="1.0&quo ...
- springboot配置双数据源 MySQL和SqlServer
1. pom文件的驱动jar包加上去, compile 'com.microsoft.sqlserver:mssql-jdbc:6.2.2.jre8' 2. application.yml sprin ...
- springboot + mybatis配置多数据源示例
转:http://www.jb51.net/article/107223.htm 在实际开发中,我们一个项目可能会用到多个数据库,通常一个数据库对应一个数据源. 代码结构: 简要原理: 1)Datab ...
- Java开发学习(三十六)----SpringBoot三种配置文件解析
一. 配置文件格式 我们现在启动服务器默认的端口号是 8080,访问路径可以书写为 http://localhost:8080/books/1 在线上环境我们还是希望将端口号改为 80,这样在访问的时 ...
- SpringMVC配置双数据源,一个java项目同时连接两个数据库
数据源在配置文件中的配置 请点击---> java架构师项目实战,高并发集群分布式,大数据高可用,视频教程 <pre name="code" class=" ...
- spring 配置双数据源并读写分离
摘自 开源项目Ibase4j 关键思想在于AbstractRoutingSource 类 还有方法名称和切入点去控制使用哪个数据源 1.首先在配置文件配置多个数据源 并且交给继承自spri ...
随机推荐
- centos6.6安装hadoop-2.5.0(六、各种node功能)
一.hadoop的YARN框架 hadoop的YARN职能就是将资源调度和任务调度分开 ResourceManager全局管理所有应用程序计算资源的分配,每一个job的ApplicationMaste ...
- curl 返回头部和正文
头部string(195) "HTTP/1.1 200 OK Server: openresty/1.7.7.1 Date: Wed, 05 Sep 2018 13:18:33 GMT Co ...
- Oracle使用exp和imp导出、导入数据
===========导出============ exp 用户名/密码@服务器(localhost) file=文件路径.dmp owner=(用户名) ===========导入========= ...
- mysql创建用户并给用户分配权限
1.登录Mysql [root@xufeng Desktop]# mysql -u root -pEnter password: Welcome to the MySQL monitor. Comma ...
- mysql关系型和非关系型区别
关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织优点:1.易于维护:都是使用表结构,格式一致:2.使用方便:SQL语言通用,可用于复杂查询:3.复杂操作:支持SQL,可用于 ...
- 配置JAVA 环境变量
首先 下载好JDK后 打开环境变量配置 配置JAVA_HOME: C:\Program Files\Java\jdk1.8.0_144(也就是jdk下载后的文件夹) 之后配置PATH:这时用到%J ...
- 16 多校8 Rikka with Parenthesis II
As we know, Rikka is poor at math. Yuta is worrying about this situation, so he gives Rikka some mat ...
- 【Python】sql-内连接,左连接,右连接,union
内连接: mysql> select * from book_wangjing as book_1 inner join user_wangjing as user_1 on book_1.id ...
- Android SO UPX壳问题小记
网上有篇 Android SO(动态链接库)UPX加固指南,详细介绍了如何使用UPX给Android SO加壳,尝试做了一下结果ok,这里只记录遇到的几个小问题. 1.40k以下so不能加壳 kiii ...
- Quorum算法
分布式系统中,一般保存多个数据副本,明显可以提高系统可靠性.并且存储这些数据副本的节点,不仅做容灾用,也可以提供服务,作负载均衡. 这里就涉及到一个数据一致性的问题,也就是各副本间要进行同步,来保持最 ...