Tomcat数据源(多)+JNDI+参数说明

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>

2-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>

以上两步实现了项目依赖tomcat的JNDI数据源,且断网之后进行操作报错,重新联网后系统正常(亲测).

3-参数说明

<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'间快速频繁波动,这不是我想要的;

5-测试jsp

将以下JSP文件放到项目根下,打开预览即可。


<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding="UTF-8"%>  
<%@ page import="javax.naming.Context" %>
<%@ page import="javax.naming.InitialContext" %>
<%@ page import="javax.sql.DataSource" %>
<%@ page import="java.sql.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>测试JNDI连接</title>  
</head>  
<body>  
<%  
Context ctx = new InitialContext();  
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/oracleDb"); 
Connection conns = null; 
try{
	conns = ds.getConnection(); 
	if(null!=conns){  
		out.println("数据库连接状态:<b>OK</b><hr />");  
		PreparedStatement pst = conns.prepareStatement("select u.login_name,u.name from users u where u.status = 'ACTIVE'");  
		ResultSet rs = pst.executeQuery();  
		while(rs.next()){ 
			String login_name = rs.getString("login_name");  
			String name = rs.getString("name");  
			out.println("<b>登录名:</b>"+login_name+"<br /><b>姓名:</b>"+name+"<hr />");  
		}  
	}else{  
		out.println("数据库连接状态:NO");  
	}
}catch (Exception e) {
	out.println(e.getMessage());  
}
%>  
</body>  
</html>


点击打开链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值