Spring整合多数据源实现动态切换

摘要:
在实际项目中,通常需要连接多个数据库,而不同的业务需求通常需要在实现过程中访问不同的数据库。useUnicode=真&characterEncoding=UTF-8连接。用户名=yahuconnection。密码=123456#######################Oracle####################x##########connection1.driver _ class=Oracle.jdbc.driver。OracleDriverconnection1.url=jdbc:Oracle:thin:@localhost:1521/MEDBconnection1.用户名=yahuconnection1.密码=123456###################SQL Server 2008##############连接2驱动程序_class=net.sourceforge.jtds.jdbc.Driverconnection2.url=jdbc:jtds:sqlserver://localhost:1433 ; 数据库名称=testconnection2.用户名=yahuconnection2.密码=123456spring配置。xml配置文件如下。将DynamicDataSourceBean添加到Spring上下文xml配置文件中,并配置DynamicDataSource的targetDataSources属性的Map映射。使用动态数据源,DynamicDataSource继承自AbstractRoutingDataSource,而AbstractRouteDataSource继承于org.springframework.jdbc。数据源AbstractDataSource,AbstractSource实现了统一的datasource接口,因此DynamicDataSource也可以用作datasource:˂!

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

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整合多数据源实现动态切换》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Word2013对公式处理:样式、自动编号、交叉引用IOS控件Label(UILabel)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Spring Boot配置多数据源并实现Druid自动切换

原文:https://blog.csdn.net/acquaintanceship/article/details/75350653 Spring Boot配置多数据源配置yml文件主数据源配置从数据源配置使用dao日志Spring Boot配置多数据源配置yml文件这里并没有对spring.datasource配置数据源,因为增加新数据源后,系统会覆盖由...

Springboot + Mybatis 多数据源配置

1、src/main/resources/application.properties 中配置好多个数据源   spring.datasource.initialize=false  #接口请求端口号、路径  server.port=9090  servcer.context-path=/  #mybatis配置  #mybatis.config-loca...

Spring Boot多数据源配置(一)durid、mysql、jpa整合

目前在做一个统计项目。需要多数据源整合,其中包括mysql和mongo。本节先讲mysql、durid、jpa与spring-boot的整合。 引入Durid包 <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</arti...

Spring+Hibernate 多数据源不同事务创建

环境:Spring 3.0 ,Hibernate 3.5 ,同类型数据库(DB2) 编前语:此片仅粗略的描述使用Spring和Hibernate采用注入方式管理多数据源在不同事务的情况下使用的方法。 涉及到的文件三个:testDaoImpl (数据库操作文件),applicationContext.xml(Spring主配置文件) ,jdbc.proper...

mybatis-plus多数据源切换失败

一、正常使用流程 https://www.kancloud.cn/tracy5546/dynamic-datasource 特性 支持 数据源分组 ,适用于多种场景 纯粹多库 读写分离 一主多从 混合模式。 支持数据库敏感配置信息 加密 ENC()。 支持每个数据库独立初始化表结构schema和数据库database。 支持无数据源启动,支持懒加载数据源...

SpringBoot集成多数据源

一、多数据源集成简介 多数据源集成使用dynamic-sring-boot-starter,github地址:https://github.com/baomidou/dynamic-datasource-spring-boot-starter,详细使用可以参考github地址。 二、BDP框架集成多数据源步骤 1、pom.xm文件引入dynamic-dat...