Tomcat中详细配置数据源及其原理解析
?
<Context path="/Exercise001" reloadable="true" docBase="D:/eclipse/workspace/Exercise001" workDir="D:/eclipse/workspace/Exercise001/work/org/apache/jsp" ><!-- my dataConnectionPool seting here start--><Resource name="jdbc/myoracle" scope="Shareable" type="javax.sql.DataSource"/>???????? <ResourceParams name="jdbc/myoracle">?????????? ?????????? <parameter>????????????????????? ?????????? <name>factory</name>?????????????????????????????????????????????????????????????????????????????????????????????????????????????<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>????????????????????? </parameter>????????????????????? <parameter>??????????????????????????????? <name>maxWait</name>?????????????????????????????? <value>5000</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>maxActive</name>????????????????????????????????? <value>4</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????? ?????????? <name>password</name>????????????????????????????????? <value>train</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>url</name>?????????????????????????????????????????????????????????????????????? <value>jdbc:oracle:thin:@database-cn:1521:train007</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>driverClassName</name>?
注意:oracle9i以上加载此驱动,而其它版本加载:racle.jdbc.OracleDriver????????????????????????????????? <value>oracle.jdbc.driver.OracleDriver</value>
?
????????????????????? </parameter>????????????????????? <parameter>????????????????????? ?????????? <name>maxIdle</name>????????????????????????????????? <value>2</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>username</name>????????????????????????????????? <value>train</value>????????????????????? </parameter>?????????? </ResourceParams>?????????? <!-- my datapool seting here end--></Context>??
2.2< Resource >配置说明如下:属性描述name指定Resource的JNDI的名字auth指定管理Resource的Manager,由两个可选值:Container和Application。Container表示由容器来创建和管理Resource,Application表示由WEB应用来创建和管理Resource。如果在web application deployment descriptor中使用<resource-ref>,这个属性是必需的,如果使用<resource-env-ref>,这个属性是可选的。type指定Resource所属的java类名2.3<ResourceParams>元素的属性如下:属性描述name指定ResourceParams的JNDI的名字,必须和Resource的name保持一致factory指定生成DataSource对象的factory的类名maxActive指定数据库连接池中处于活动状态的数据库连接最大数目,0表示不受限制maxIdle指定数据库连接池中处于空闲状态的数据库连接的最大数目,0表示不受限制maxWait指定数据库连接池中的数据库连接处于空闲状态的最长时间(单位为毫秒),超过这一事件,将会抛出异常。-1表示可以无限期等待。username指定连接数据库的用户名password指定连接数据库的密码driverClassName指定连接数据库的JDBC驱动程序url指定连接数据库的URL2.3引用数据源如果在web应用中访问了由Servlet容器管理的某个JNDI Resource,则必须在web.xml中声明对这个JNDI Resource的引用。表示资源引用的元素为<resource-ref>,该元素加在<wepapp></ wepapp >中。打开你的应用配置文件web.xml,输入以下粗体部分:<wepapp>……<resource-ref><descryiption>DB Connection</descryiption>
<res-ref-name>?jdbc/myoracle?</res-ref-name>
<res-type>javax.sql.DataSource </res- type>
<res-auth>Container </res-auth>
</resource-ref></ wepapp >2.4<resource-ref>元素的属性如下:属性描述description对所引用的资源的说明res-ref-name指定所引用资源的JNDI名字,与<Resource>元素中的name属性保持一致res-type指定所引用资源的类名字,与<Resource>元素中的type属性保持一致res-auth指定所引用资源的Manager,与<Resource>元素中的auth属性保持一致2.5测试数据源?????首先,检查Tomcat的%Tomcat _Home%/common/lib下有commons-collections.jar、commons-dbcp.jar、commons-pool.jar包,如果没现有,请到此地下载:http://tomcat.apache.org/?????注意以上三个包不要引入你的工程类路径,否则可能报错。?????然后,将驱动包放入%Tomcat _Home%/common/lib下,注意包必须为.jar后缀。Tomcat只认.jar包。配置完成后,写个测试,如下:<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD?
HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body>
<%
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup("java:/comp/env");
DataSource db = (DataSource)envContext.lookup("jdbc/myoracle?");
Connection conn = db.getConnection( );
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM?test");
while(rs.next()){
out.print(rs.getString("admin_name")+" ");
out.print(rs.getString("admin_password")+"<br>");
}
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
?
此属性必需????????????????????? ?????????? <name>factory</name>???????????????????????????????? ??????????????????????????????? ?????????? <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
?
????????????????????? </parameter>????????????????????? <parameter>????????????????????? <name>maxWait</name>????????????????????? <value>5000</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>maxActive</name>????????????????????????????????? <value>4</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????? ?????????? <name>password</name>????????????????????????????????? <value>train</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>url</name>?????????????????????????? ?????????? <value>jdbc:oracle:thin:@database-cn:1521:train007</value>????????????????????? </parameter>????????????????????? <parameter>?
注意:oracle9i以上加载此驱动,而其它版本加载:racle.jdbc.OracleDriver????????????????????????????????? <name>driverClassName</name>
?
????????????????????????????????? <value>oracle.jdbc.driver.OracleDriver</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????? ?????????? <name>maxIdle</name>????????????????????????????????? <value>2</value>????????????????????? </parameter>????????????????????? <parameter>????????????????????????????????? <name>username</name>????????????????????????????????? <value>train</value>????????????????????? </parameter>?????????? </ResourceParams>?????????? <!-- my datapool seting here end--></GlobalNamingResources>3.2?引用数据源由于我们配置的是容器全局数据源,因此所有的应用都可以引用这个数据源。在你的应用中建立引用,在<Context></Context>之间输入以下粗体部分:
<Context path="/Exercise001" reloadable="true" docBase="D:/eclipse/workspace/Exercise001" workDir="D:/eclipse/workspace/Exercise001/work/org/apache/jsp" >
<ResourceLink name="myDB"??????????????????? ???global="jdbc/myoracle"???????????????????????type="javax.sql.DataSource"/>
</Context>3.3 配置应用文件web.xml打开你的应用配置文件web.xml,输入以下粗体部分:<wepapp>……<resource-ref><descryiption>DB Connection</descryiption>
<res-ref-name>myDB</res-ref-name>
<res-type>javax.sql.DataSource </res- type>
<res-auth>Container </res-auth>
</resource-ref></ wepapp >??3.4测试??创建测试文件:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD?
HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body>
<%
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup("java:/comp/env");
DataSource db = (DataSource)envContext.lookup("myDB?");//名称与web.xml配置中的一致
Connection conn = db.getConnection( );
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM?test");
while(rs.next()){
out.print(rs.getString("admin_name")+" ");
out.print(rs.getString("admin_password")+"<br>");
}
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
?