全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Spring整合多数据源实现动态切换的实例讲解

在实际项目中时常需要连接多个数据库,而且不同的业务需求在实现过程当中往往需要访问不同的数据库。

jdbc.properties配置文件,配置多个dataSource

##########################MySQL#####################################
hibernate.dialect=org.hibernate.dialect.MySQLInnoDBDialect
connection.driver_class=com.mysql.jdbc.Driver
connection.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8
connection.username=yahu
connection.password=123456

##########################Oracle#####################################
connection1.driver_class=oracle.jdbc.driver.OracleDriver
connection1.url=jdbc\:oracle\:thin\:@localhost\:1521/MEDB
connection1.username=yahu
connection1.password=123456

##########################Sql Server2008#####################################
connection2.driver_class=net.sourceforge.jtds.jdbc.Driver
connection2.url=jdbc:jtds:sqlserver://localhost:1433;DatabaseName=test
connection2.username=yahu
connection2.password=123456

spring-config.xml配置文件如下,将DynamicDataSource Bean加入到Spring的上下文xml配置文件中去,同时配置DynamicDataSource的targetDataSources(多数据源目标)属性的Map映射,使用动态数据源DynamicDataSource是继承与AbstractRoutingDataSource,而AbstractRoutingDataSource又是继承于org.springframework.jdbc.datasource.AbstractDataSource,AbstractDataSource实现了统一的DataSource接口,所以DynamicDataSource同样可以当一个DataSource使用:

<!-- 数据库连接池配置 -->
  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="${connection.driver_class}" />
  <property name="url" value="${connection.url}" />
  <property name="username" value="${connection.username}" />
  <property name="password" value="${connection.password}" />
  
  <property name="initialSize" value="5" />
  <property name="minIdle" value="1" /> 
  <property name="maxActive" value="200" />
  
  <!-- 配置获取连接等待超时的时间 -->
  <property name="maxWait" value="30000" />
  
  <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
  <property name="timeBetweenEvictionRunsMillis" value="60000" />
  
  <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
  <property name="minEvictableIdleTimeMillis" value="300000" />
 </bean>
 
 <!-- Oracle -->
 <bean id="dataSource1" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="${connection1.driver_class}" />
  <property name="url" value="${connection1.url}" />
  <property name="username" value="${connection1.username}" />
  <property name="password" value="${connection1.password}" />
 </bean>

 <!-- Sql server 2008 -->
 <bean id="dataSource2" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="${connection2.driver_class}" />
  <property name="url" value="${connection2.url}" />
  <property name="username" value="${connection2.username}" />
  <property name="password" value="${connection2.password}" />
 </bean>
 
  <!-- 动态数据源 -->
  <bean id="dynamicDataSource" class="com.yahu.core.dao.DynamicDataSource"> 
  <!-- 通过key-value的形式来关联数据源 --> 
  <property name="targetDataSources"> 
   <map> 
    <entry value-ref="dataSource" key="datasource" /> 
    <entry value-ref="dataSource1" key="datasource1" />
    <entry value-ref="dataSource2" key="datasource2" />   
   </map> 
  </property> 
  <property name="defaultTargetDataSource" ref="dataSource" /> 
 </bean>

DynamicDataSource动态数据源类,扩展Spring的AbstractRoutingDataSource抽象类,实现动态数据源,AbstractRoutingDataSource中的抽象方法determineCurrentLookupKey是实现数据源的route的核心.这里对该方法进行Override:

package com.yahu.core.dao;
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;

/*******************************************************************
 * @describe : 建立动态数据源类 必须继承AbstractRoutingDataSource
 ********************************************************************/
public class DynamicDataSource extends AbstractRoutingDataSource {
 //coverity 修改
 //private Log log = LogFactory.getLog(getClass());

 protected Object determineCurrentLookupKey() {
  String value = CustomerContextHolder.getCustomerType();
  //log.info(value);
  return value;
 }

}

获得和设置上下文环境,为一线程安全的ThreadLocal:

package com.yahu.core.dao;

/*******************************************************************
 * @describe : 获得和设置上下文环境
 ********************************************************************/
public class CustomerContextHolder {

 /**
  * mysql
  */
 public static final String DATASOURCE = "datasource";

 /**
  * oracle
  */
 public static final String DATASOURCE_1 = "datasource1";
 
 /**
  * sql server
  */
 public static final String DATASOURCE_2 = "datasource2";

 private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();

 public static void setCustomerType(String customerType) {
  contextHolder.set(customerType);
 }

 public static String getCustomerType() {
  return contextHolder.get();
 }

 public static void clearCustomerType() {
  contextHolder.remove();
 }
}

动态数据源的管理,如何选择控制每个业务中需要的具体数据源,可以使用手动控制,业务层通过加入以下代码

CustomerContextHolder.setCustomerType(CustomerContextHolder.DATASOURCE);

即可实现动态切换数据源,如果在service层有比较统一的规则的话,也可以使用aop设置数据源使用,这里一般都是一个service一个数据源,所以最好使用aop在service层执行完之后统一调用

CustomerContextHolder.clearCustomerType();

清空数据源信息。

当然,在上面配置里面有个参数defaultTargetDataSource为默认数据源,就是不设置数据源的话,就是用这个数据源。

以上这篇Spring整合多数据源实现动态切换的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# java多数据源动态切换  # Spring Boot 动态数据源示例(多数据源自动切换)  # Springboot如何设置多数据源  # 随时切换  # SpringBoot AOP方式实现多数据源切换的方法  # Spring实现动态切换多数据源的解决方案  # spring boot+mybatis 多数据源切换(实例讲解)  # Spring配置多数据源切换  # 详解Spring多数据源如何切换  # Spring通过拦截器实现多数据源切换的示例代码  # 配置文件  # 多个  # 给大家  # 可以使用  # 都是  # 有个  # 又是  # 希望能  # 在上面  # 这篇  # 中去  # 小编  # 如何选择  # 大家多多  # 清空  # 池中  # 实现了  # 多久  # 连接池  # 抽象类 


相关文章: 建站之星24小时客服电话如何获取?  临沂网站制作企业,临沂第三中学官方网站?  音响网站制作视频教程,隆霸音响官方网站?  潮流网站制作头像软件下载,适合母子的网名有哪些?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  家庭建站与云服务器建站,如何选择更优?  北京网站制作网页,网站升级改版需要多久?  建站主机选择指南:服务器配置与SEO优化实战技巧  学校免费自助建站系统:智能生成+拖拽设计+多端适配  高端智能建站公司优选:品牌定制与SEO优化一站式服务  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  成都网站制作报价公司,成都工业用气开户费用?  网站制作免费,什么网站能看正片电影?  如何挑选优质建站一级代理提升网站排名?  如何在阿里云ECS服务器部署织梦CMS网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  如何生成腾讯云建站专用兑换码?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  网站制作说明怎么写,简述网页设计的流程并说明原因?  长沙企业网站制作哪家好,长沙水业集团官方网站?  如何通过商城自助建站源码实现零基础高效建站?  平台云上自主建站:模板化设计与智能工具打造高效网站  定制建站哪家更专业可靠?推荐榜单揭晓  建站之星会员如何解锁更多建站功能?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  建站主机是否等同于虚拟主机?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  建站之星价格显示格式升级,你的预算足够吗?  音乐网站服务器如何优化API响应速度?  ,网页ppt怎么弄成自己的ppt?  制作网站的软件免费下载,免费制作app哪个平台好?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  Python如何创建带属性的XML节点  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  网站制作公司,橙子建站是合法的吗?  制作网站公司那家好,网络公司是做什么的?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  模具网站制作流程,如何找模具客户?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  如何用PHP工具快速搭建高效网站?  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  建站之星后台密码遗忘或太弱?如何重置与强化?  Python lxml的etree和ElementTree有什么区别  简历在线制作网站免费,免费下载个人简历的网站是哪些?  网站微信制作软件,如何制作微信链接?  中山网站推广排名,中山信息港登录入口?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  如何通过WDCP绑定主域名及创建子域名站点?  如何在云主机上快速搭建网站?  利用JavaScript实现拖拽改变元素大小 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。