springboot 多数据源的实现
相关的依赖

yml配置

java配置类:

DataSourceConfigurerjava
/**
* Created by zhiqi.shao on 2017/11/20.
*/
@Configuration
public class DataSourceConfigurer {
@Bean
@ConfigurationProperties("datasource.order")
public DataSourceProperties orderDataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@ConfigurationProperties("datasource.order")
public DataSource orderDataSource() {
return orderDataSourceProperties().initializeDataSourceBuilder().build();
}
@Bean
@Primary
@ConfigurationProperties("datasource.order-query")
public DataSourceProperties orderQueryDataSourceProperties() {
return new DataSourceProperties();
}
@Bean
@Primary
@ConfigurationProperties("datasource.order-query")
public DataSource orderQueryDataSource() {
return orderQueryDataSourceProperties().initializeDataSourceBuilder().build();
}
}
OrderDataSourceConfigurer.java
/**
* Created by zhiqi.shao on 2017/11/20.
*/
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
entityManagerFactoryRef = "entityManagerFactoryOrder",
transactionManagerRef = "transactionManagerOrder",
basePackages = {"com.hpe.ordersynchro.ordersEntity"}
)
public class OrderDataSourceConfigurer {
@Autowired
@Qualifier("orderDataSource")
private DataSource orderDataSource;
@Bean(name = "entityManagerOrder")
public EntityManager entityManager(EntityManagerFactoryBuilder builder){
return entityManagerFactoryOrder(builder).getObject().createEntityManager();
}
@Bean(name= "entityManagerFactoryOrder")
public LocalContainerEntityManagerFactoryBean entityManagerFactoryOrder(EntityManagerFactoryBuilder builder){
return builder
.dataSource(orderDataSource)
.properties(getVendorProperties(orderDataSource))
.packages(new String[]{"com.hpe.ordersynchro.ordersEntity"})
.persistenceUnit("orderPersistenceUnit")
.build();
}
@Autowired
private JpaProperties jpaProperties;
private Map<String,String> getVendorProperties(DataSource dataSource){
return jpaProperties.getHibernateProperties(dataSource);
}
@Bean(name ="transactionManagerOrder")
public PlatformTransactionManager transactionManagerOrder(EntityManagerFactoryBuilder builder){
return new JpaTransactionManager((entityManagerFactoryOrder(builder).getObject()));
}
OrderQueryDataSourceConfigurer.java
/**
* Created by zhiqi.shao on 2017/11/20.
*/
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
entityManagerFactoryRef = "entityManagerFactoryOrderQuery",
transactionManagerRef = "transactionManagerOrderQuery",
basePackages = {"com.hpe.ordersynchro.ordersQueryEntity"}
)
public class OrderQueryDataSourceConfigurer {
@Autowired
@Qualifier("orderQueryDataSource")
private DataSource orderQueryDataSource;
@Primary
@Bean(name = "entityManagerOrderQuery")
public EntityManager entityManager(EntityManagerFactoryBuilder builder){
return entityManagerFactoryOrderQuery(builder).getObject().createEntityManager();
}
@Primary
@Bean(name= "entityManagerFactoryOrderQuery")
public LocalContainerEntityManagerFactoryBean entityManagerFactoryOrderQuery(EntityManagerFactoryBuilder builder){
return builder
.dataSource(orderQueryDataSource)
.properties(getVendorProperties(orderQueryDataSource))
.packages(new String[]{"com.hpe.ordersynchro.ordersQueryEntity"})
.persistenceUnit("orderQueryPersistenceUnit")
.build();
}
@Autowired
private JpaProperties jpaProperties;
private Map<String,String> getVendorProperties(DataSource dataSource){
return jpaProperties.getHibernateProperties(dataSource);
}
@Primary
@Bean(name ="transactionManagerOrderQuery")
public PlatformTransactionManager transactionManagerOrderQuery(EntityManagerFactoryBuilder builder){
return new JpaTransactionManager((entityManagerFactoryOrderQuery(builder).getObject()));
}
}
注解:加了@primary就是默认数据源


分别是jpa和jpa对应实体的位置,我这里还是将它们放在了一个包下,所以上面配置的扫描路劲相同:

springboot 多数据源的实现的更多相关文章
- Spring-Boot配置文件数据源配置项
Spring-Boot配置文件数据源配置项(常用配置项为红色) 参数 介绍 spring.datasource.continue-on-error = false 初始化数据库时发生错误时,请勿停止 ...
- SpringBoot多数据源动态切换数据源
1.配置多数据源 spring: datasource: master: password: erp_test@abc url: jdbc:mysql://127.0.0.1:3306/M201911 ...
- SpringBoot学习笔记(三):SpringBoot集成Mybatis、SpringBoot事务管理、SpringBoot多数据源
SpringBoot集成Mybatis 第一步我们需要在pom.xml里面引入mybatis相关的jar包 <dependency> <groupId>org.mybatis. ...
- 搞定SpringBoot多数据源(1):多套源策略
目录 1. 引言 2. 运行环境 3. 多套数据源 3.1 搭建 Spring Boot 工程 3.1.1 初始化 Spring Boot 工程 3.1.2 添加 MyBatis Plus 依赖 3. ...
- 搞定SpringBoot多数据源(2):动态数据源
目录 1. 引言 2. 动态数据源流程说明 3. 实现动态数据源 3.1 说明及数据源配置 3.1.1 包结构说明 3.1.2 数据库连接信息配置 3.1.3 数据源配置 3.2 动态数据源设置 3. ...
- 搞定SpringBoot多数据源(3):参数化变更源
目录 1. 引言 2. 参数化变更源说明 2.1 解决思路 2.2 流程说明 3. 实现参数化变更源 3.1 改造动态数据源 3.1.1 动态数据源添加功能 3.1.2 动态数据源配置 3.2 添加数 ...
- SpringBoot多数据源:动态数据源
目录 1. 引言 2. 动态数据源流程说明 3. 实现动态数据源 3.1 说明及数据源配置 3.1.1 包结构说明 3.1.2 数据库连接信息配置 3.1.3 数据源配置 3.2 动态数据源设置 3. ...
- Springboot 多数据源配置,结合tk-mybatis
一.前言 作为一个资深的CRUD工程师,我们在实际使用springboot开发项目的时候,难免会遇到同时使用多个数据库的情况,比如前脚刚查询mysql,后脚就要查询sqlserver. 这时,我们很直 ...
- springBoot多数据源(不同类型数据库)项目
一个基于springboot的多数据源(mysql.sqlserver)项目,先看看项目结构,注意dao层 多数据源mysql配置代码: package com.douzi.robotcenter.c ...
- springboot 双数据源+aop动态切换
# springboot-double-dataspringboot-double-data 应用场景 项目需要同时连接两个不同的数据库A, B,并且它们都为主从架构,一台写库,多台读库. 多数据源 ...
随机推荐
- MySQL下做Master/Slave同步,延迟太大怎么办?
slave的延迟是比较常见的,如果短暂的延迟后还能追上,一般就能接受了. 用innodb不是坏事,会减少一些slave中止的情况.如果是myisam的表,insert update delete操 ...
- [国家集训队2012]tree(陈立杰)
[国家集训队2012]tree(陈立杰) 题目 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有need条白色边的生成树.题目保证有解. INPUT 第一行V,E,need分别表示 ...
- 优化实例- not in 和 not exists
客户运行一个SQL,非常慢.于是进行了一下改写.速度飞快,首先看一下原来的SQL. original sql SQL> explain plan for 2 select count(*) fr ...
- Mac OSX:安装zsh
想在mac下安装oh my zsh,按照https://github.com/robbyrussell/oh-my-zsh上的文档,执行下面这条命令安装:curl -L http://install. ...
- HDU 5393
[background] 保研的事终于告一段落了,之后去北京折腾了一段时间,本以为会在那里实习一个月,谁知道刚去ICT,心中就各种反感,可能是因为LP的态度吧,否则我可能会留在那里读研也说不定.花了两 ...
- SIS
故障: 1.2017-12-14 发现前期测试的钉钉切换校区功能有遗留问题,第二个校区进行考勤后,在考勤记录中编辑考勤记录,出现无权限 原因:编辑考勤记录,传的schoolid不是原先的school ...
- Navicat Lite 提示Connection to mysql server on 10065
Navicat Lite 提示Connection to mysql server on 10065 验证过主要是防火墙问题 [root@014136251035 zhop]# vi /etc/sys ...
- javase - 点餐系统
public class OrderMsg { public static void main(String[] args) throws Exception { /** * 订餐人姓名.选择菜品.送 ...
- 修复nexus4由于使用完美刷机或者刷机精灵导致的底层文件受损
前一段nexus4升级android 4.4.4的时候突然发现无法使用线刷刷入官方镜像了.当时就感觉很奇怪,但是不知道怎么搞得刷进去了,但是第一次开机的时候总是卡在联网之后的验证(我当时以为是网络不好 ...
- B1001 狼抓兔子 最小割
题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...