码迷,mamicode.com
首页 > 编程语言 > 详细

利用Spring的AbstractRoutingDataSource解决多数据源的问题

时间:2017-07-05 10:01:56      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:html   util   protected   map   tag   views   pass   解决   项目   

多数据源问题很常见,例如读写分离数据库配置。

原来的项目出现了新需求,局方要求新增某服务器用以提供某代码,涉及到多数据源的问题。

研究成果如下:

1、首先配置多个datasource

 

[html] view plain copy
 
  1. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">  
  2.         <property name="driverClassName" value="net.sourceforge.jtds.jdbc.Driver">  
  3.         </property>  
  4.         <property name="url" value="jdbc:jtds:sqlserver://10.82.81.51:1433;databaseName=standards">  
  5.         </property>  
  6.         <property name="username" value="youguess"></property>  
  7.         <property name="password" value="youguess"></property>  
  8.     </bean>  
  9.     <bean id="dataSource2" class="org.apache.commons.dbcp.BasicDataSource">  
  10.         <property name="driverClassName" value="net.sourceforge.jtds.jdbc.Driver">  
  11.         </property>  
  12.         <property name="url" value="jdbc:jtds:sqlserver://10.82.81.52:1433;databaseName=standards">  
  13.         </property>  
  14.         <property name="username" value="youguess"></property>  
  15.         <property name="password" value="youguess"></property>  
  16. </bean>  



 

2、写一个DynamicDataSource类继承AbstractRoutingDataSource,并实现determineCurrentLookupKey方法

 

[java] view plain copy
 
  1. package com.standard.core.util;  
  2. import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;  
  3. public class DynamicDataSource extends AbstractRoutingDataSource {  
  4.     @Override  
  5.     protected Object determineCurrentLookupKey() {  
  6.         return CustomerContextHolder.getCustomerType();  
  7.     }  
  8. }  



 

 

3、利用ThreadLocal解决线程安全问题

 

[java] view plain copy
 
  1. package com.standard.core.util;  
  2. public class CustomerContextHolder {  
  3.     public static final String DATA_SOURCE_A = "dataSource";  
  4.     public static final String DATA_SOURCE_B = "dataSource2";  
  5.     private static final ThreadLocal<String> contextHolder = new ThreadLocal<String>();  
  6.     public static void setCustomerType(String customerType) {  
  7.         contextHolder.set(customerType);  
  8.     }  
  9.     public static String getCustomerType() {  
  10.         return contextHolder.get();  
  11.     }  
  12.     public static void clearCustomerType() {  
  13.         contextHolder.remove();  
  14.     }  
  15. }  


4、数据源配置

 

 

[html] view plain copy
 
  1. <bean id="dynamicDataSource" class="com.standard.core.util.DynamicDataSource" >  
  2.         <property name="targetDataSources">  
  3.             <map key-type="java.lang.String">  
  4.                 <entry value-ref="dataSource" key="dataSource"></entry>  
  5.                 <entry value-ref="dataSource2" key="dataSource2"></entry>  
  6.             </map>  
  7.         </property>  
  8.         <property name="defaultTargetDataSource" ref="dataSource" >  
  9.         </property>  
  10.     </bean>   


5、在DAOImpl中切换数据源

 

 

[java] view plain copy
 
  1. CustomerContextHolder.setCustomerType(CustomerContextHolder.DATA_SOURCE_B);   


搞定!

利用Spring的AbstractRoutingDataSource解决多数据源的问题

标签:html   util   protected   map   tag   views   pass   解决   项目   

原文地址:http://www.cnblogs.com/dayuyanwei/p/7119467.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!