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

标签 java spring spring-mvc datasource spring-jdbc

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

这是代码:

调度程序-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); 
    }

}

BaseNamedParameterJdbcDaoSupportForMirrorDB.java:

public class BaseNamedParameterJdbcDaoSupportForMirrorDB extends NamedParameterJdbcDaoSupport{

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

}

最佳答案

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

检查您的 DAO/服务代码,以利用适当的 @Autowired 的“BaseNamedParameterJdbcDaoSupport”和“BaseNamedParameterJdbcDaoSupportForMirrorDB”。

关于java - Spring MVC 中的多数据源切换问题。当第二个数据源不可用时,它会自动使用第一个数据源,其中引用第二个数据源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53426087/

相关文章:

java - 如何在 SQL 字符串中插入多个 where 子句

java - 平均一个方法的多个结果?

spring - SimpleJdbcInsert 等价于更新

java - Spring Jpa 更新 : Can not issue data manipulation statements with executeQuery()

java - 可以告诉 MapStruct 不执行自动映射吗?

java - Spring @Controller 异常处理程序和全局异常处理程序。如何调用两者

java - 如何配置 Spring Boot 以使用两个数据库?

SpringServletContainerInitializer 不能强制转换为 javax.servlet.ServletContainerInitializer

java - 如何使我的 URL 仅为 "localhost:8080/*"?

java - 来自 Hibernate 的 Spring MVC View 的数据