Spring MVC中的多数据源切换问题.当第二个数据源不可用时,它会自动使用引用第二个的第一个数据源



我在SpringMVC项目中配置了2个数据源,但当第二个dataSource不可用,它会自动使用引用第二个数据源的第一个数据源。我想停止这种切换。

这是代码:

dispatcher-servlet.xml:

<bean id="transactionManager"  class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="dataSource" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource" lazy-init="false">
<property name="driverClassName" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="defaultAutoCommit" value="true"/>
<property name="testOnBorrow" value="true"/>
<property name="initialSize" value="1"/>
<property name="maxActive" value="1"/>
<property name="maxWait" value="500"/>
<property name="maxIdle" value="2"/>
</bean> 
<bean id="dataSource1" destroy-method="close" class="org.apache.commons.dbcp.BasicDataSource" lazy-init="false">
<property name="driverClassName" value="${jdbc.driverClassName1}"/>
<property name="url" value="${jdbc.url1}"/>
<property name="username" value="${jdbc.username1}"/>
<property name="password" value="${jdbc.password1}"/>
<property name="defaultAutoCommit" value="true"/>
<property name="testOnBorrow" value="true"/>
<property name="initialSize" value="1"/>
<property name="maxActive" value="3"/>
<property name="maxWait" value="500"/>
<property name="maxIdle" value="8"/> 
</bean>

BaseNamedParameterJdbcDaoSupport.java类:

public class BaseNamedParameterJdbcDaoSupport extends NamedParameterJdbcDaoSupport{
@Autowired
public void setDataSourceFor1(DataSource dataSource) {        
//      System.out.println("Main DS"+dataSource);
setDataSource(dataSource); 
}
}

基本名称参数JdbcDaoSupportForMirrorDB.java:

public class BaseNamedParameterJdbcDaoSupportForMirrorDB extends NamedParameterJdbcDaoSupport{
@Autowired
public void setDataSourceFor2(DataSource dataSource1) {  
//      System.out.println("ForMirrorDB dataSource1"+dataSource1); 
setDataSource(dataSource1); 
}
}

用不同名称维护的DataSource不可能自动切换。我认为您已经实现了一些其他逻辑来处理这两个DataSource对象。

检查您的DAO/Service代码以使用"BaseNamedParameterJdbcDaoSupport"&"BaseNamedParameterJdbcDaoSupportForMirrorDB",带有适当的@Autowired。

最新更新