tomcat配置jndi数据源

1.在conf/context.xml下加入配置

    <Context>
        <WatchedResource>WEB-INF/web.xml</WatchedResource>
        <Resource name="jdbc/oracleDb"      
            auth="Container"  
            type="javax.sql.DataSource"  
            driverClassName="oracle.jdbc.OracleDriver"  
            url="jdbc:oracle:thin:@192.168.10.92:1521:orcl"  
            username="xxjsb"  
            password="xxjsb"  
            maxActive="500"  
            maxIdle="500"  
            maxWait="36000"  
    	    #解决网络超时或者断网或者数据库重启的问题
    	    logAbandoned="true"  
    	    removeAbandoned="true" 
    	    removeAbandonedTimeout="10"
    	    #DBCP连接池的自我检测
    	    validationQuery = "select 1 from dual"
    	    testWhileIdle = "true"
    	    testOnBorrow = "false"
    	    timeBetweenEvictionRunsMillis = "30000"
    	    minEvictableIdleTimeMillis = "1800000"
    	    numTestsPerEvictionRun="3"
        /> 
    	<Resource name="jdbc/extendDataNo1"      
            auth="Container"  
            type="javax.sql.DataSource"  
            driverClassName="oracle.jdbc.OracleDriver"  
            url="jdbc:oracle:thin:@192.168.10.92:1521:orcl"  
            username="middle"  
            password="middle"  
            maxActive="30"  
            maxIdle="20"  
            maxWait="36000"
         /> 
    </Context>

spring配置文件增加数据源引用(如:dataSourceContext.xml)

    <beans>
    	<bean id="dataSource"  class="org.springframework.jndi.JndiObjectFactoryBean">  
            <property name="jndiName" value="java:comp/env/jdbc/oracleDb"/>  
        </bean> 
    	<bean id="extendDataNo1"  class="org.springframework.jndi.JndiObjectFactoryBean">  
            <property name="jndiName" value="java:comp/env/jdbc/extendDataNo1"/>  
        </bean>
    </beans>

参数说明:

<parame 
    maxActive="最大激活连接数,这里取值为500,表示同时最多有500个数据库连接"  
    maxIdle="最大的空闲连接数,这里取值为500,表示即使没有数据库连接时依然可以保持500空闲的连接,
    		而不被清除,随时处于待命状态"  
    maxWait="连接最大的等待时间,单位毫秒,如果超过此时间将接到异常.设为-1表示无限制"
    #解决网络超时或者断网或者数据库重启的问题
    logAbandoned="true"  
    removeAbandoned="true" 
    removeAbandonedTimeout="连接泄漏回收参数,单位秒,泄露的连接可以被删除的超时值"
    #DBCP连接池的自我检测
    validationQuery="验证连接是否可用,使用的SQL语句"  
    testWhileIdle="指明连接是否被空闲连接回收器(如果有)进行检验.
    				如果检测失败,则连接将被从池中去除"      .
    testOnBorrow="借出连接时不要测试,否则很影响性能"
    timeBetweenEvictionRunsMillis = "每30秒运行一次空闲连接回收器,单位毫秒"  
    minEvictableIdleTimeMillis = "池中的连接空闲30分钟后被回收,默认值就是30分钟,单位毫秒"
    numTestsPerEvictionRun="在每次空闲连接回收器线程(如果有)运行时检查的连接数量,默认值就是3" 
    #DBCP连接池的自我检测解释:
    配置 timeBetweenEvictionRunsMillis = "30000"后,每30秒运行一次空闲连接回收器(独立线程),并每次检查3个连接,如果连接空闲时间超过30分钟就销毁.
    销毁连接后,连接数量就少了,如果小于'minIdle'数量,就新建连接,维护数量不少于'minIdle'.
    testWhileIdle = "true" 表示每30秒,取出3条连接,使用'validationQuery'中的SQL进行测试,测试不成功就销毁连接.销毁连接后,
    连接数量就少了,如果小于'minIdle'数量,就新建连接.
    testOnBorrow = "false" 一定要配置,因为它的默认值是true.false表示每次从连接池中取出连接时,不需要执行'validationQuery'
    中的SQL进行测试.若配置为true,对性能有非常大的影响,性能会下降7-10倍.所在一定要配置为false.
    每30秒,取出'numTestsPerEvictionRun'条连接(本例是3,也是默认值),发出"SELECT 1" SQL语句进行测试 ,测试过的连接不算是“被使用”了,
    还算是空闲的.连接空闲30分钟后会被销毁.
 />

4-注意事项
'maxIdle'值与'maxActive'值应配置的接近。
因为,当连接数超过maxIdle值后,刚刚使用完的连接(刚刚空闲下来)会立即被销毁.
而不是我想要的空闲M秒后再销毁起一个缓冲作用.这一点DBCP做的可能与你想像的不一样;
若'maxIdle'与'maxActive'相差较大,在高负载的系统中会导致频繁的创建、销毁连接,
连接数在'maxIdle'与'maxActive'间快速频繁波动,这不是我想要的;

版权声明:
作者:Ykuee
链接:https://www.ykuee.link/archives/145
来源:Ykuee的博客
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
< <上一篇
下一篇>>