Spring多数据源的配置

C3P0和DBCP的区别

C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。 

dbcp简介: 

DBCP(DataBase connection pool),数据库连接池。是 apache 上的一个 java 连接池项目,也是 tomcat 使用的连接池组件。单独使用dbcp需要3个包:common-dbcp.jar,common-pool.jar,common-collections.jar由于建立数据库连接是一个非常耗时耗资源的行为,所以通过连接池预先同数据库建立一些连接,放在内存中,应用程序需要建立数据库连接时直接到连接池中申请一个就行,用完后再放回去。 

c3p0与dbcp区别: 

dbcp没有自动的去回收空闲连接的功能  c3p0有自动回收空闲连接功能 

两者主要是对数据连接的处理方式不同!C3P0提供最大空闲时间,DBCP提供最大连接数。

前者当连接超过最大空闲连接时间时,当前连接就会被断掉。DBCP当连接数超过最大连接数时,所有连接都会被断开

1、首先配置多个datasource

<!-- 主数据库的数据据源 -->
    <bean
        destroy-method="close">
        <property value="Oracle.jdbc.OracleDriver" />
        <property value="jdbc:oracle:thin:@192.168.10.11:1521:trew" />
        <property value="poi" />
        <property value="poi" />
    </bean>
    <!-- 备份库的数据据源 -->
    <bean
        destroy-method="close">
        <property value="oracle.jdbc.OracleDriver" />
        <property value="jdbc:oracle:thin:@192.168.10.12:1521:trew" />
        <property value="poi2" />
        <property value="poi2" />
    </bean>

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

public class DynamicDataSource extends AbstractRoutingDataSource {

@SuppressWarnings("unused")

private Log logger = LogFactory.getLog(getClass());

@Override

protected Object determineCurrentLookupKey() {

return DbContextHolder.getDbType();

}

}

public class DbContextHolder {

@SuppressWarnings("rawtypes")

private static final ThreadLocal contextHolder = new ThreadLocal();

@SuppressWarnings("unchecked")

public static void setDbType(String dbType) {

contextHolder.set(dbType);

}

public static String getDbType() {

return (String) contextHolder.get();

}

public static void clearDbType() {

contextHolder.remove();

}

}  

3. 配置动态数据源

<!--将DynamicDataSource Bean加入到Spring的上下文xml配置文件中去,同时配置DynamicDataSource的targetDataSources(多数据源目标)属性的Map映射。-->

<bean>
        <property>
            <map key-type="java.lang.String">
                <entry key="masterDataSource" value-ref="masterDataSource" />
                <entry key="slaveDataSource"  value-ref="slaveDataSource"  />
            </map>
        </property>
        <property ref="masterDataSource"/>
    </bean>

4.使用动态数据源(hibernate)

<bean
       >
        <property ref="dataSource" />
        <property ref="lobHandler"/>
        <property>
            <map>
                <entry key="post-insert">
                    <ref bean="logListener"/>
                </entry>
                <entry key="post-update">
                    <ref bean="logListener"/>
                </entry>
                <entry key="post-delete">
                    <ref bean="logListener"/>
                </entry>
            </map>
        </property>
        <property>
            <props>
                <prop key="hibernate.dialect">
                org.hibernate.dialect.Oracle10gDialect
                <!-- org.hibernate.dialect.OracleDerbyDialect -->   
                </prop>
                <prop key="hibernate.show_sql">true</prop>
                <!-- <prop key="hibernate.generate_statistics">true</prop> -->
                <prop key="hibernate.connection.release_mode">
                    auto
                </prop>
                <prop key="hibernate.autoReconnect">true</prop>
                <!--
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                -->
                <prop key="hibernate.cache.use_second_level_cache">false</prop> 
                <prop key="hibernate.cache.provider_class">
                    org.hibernate.cache.EhCacheProvider
                </prop>
                <prop key="hibernate.cache.use_query_cache">false</prop>
               
            </props>
        </property>
    </bean>

使用Hibernate时的事务管理配置示例:

<bean> 
  < property ref="sessionFactory" /> 
bean>

6.动态数据源的管理控制

1.可以根据不同的DAO注入目标sessionfactory

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/9079c8247a4c692c321dd431006dd96d.html