您的位置:首页 > 运维架构 > Tomcat

Tomcat配置数据源连接池

2010-01-31 13:38 337 查看
今天遇到了关于数据源连接池配置的问题,发现有很多种方式可以配置,现总结如下,希望对大家有所帮助:(已Mysql数据库为例)

  一、Tomcat配置数据源:

  方式一:在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,内容如下:

  <Context>

   <Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource"

   maxActive="50" maxIdle="30" maxWait="10000" logAbandoned="true"

   username="root" password="111111" driverClassName="com.mysql.jdbc.Driver"

   url="jdbc:mysql://localhost:3306/testdb" />

  </Context>

  方式二:在tomcat6.0的目录conf下面的context.xml中,修改原来的context标签,改成内容如下:

  <Context>

   <!-- Default set of monitored resources -->

   <WatchedResource>WEB-INF/web.xml</WatchedResource>

   <Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource"

   maxActive="50" maxIdle="30" maxWait="10000" logAbandoned="true"

   username="root" password="111111" driverClassName="com.mysql.jdbc.Driver"

   url="jdbc:mysql://localhost:3306/testdb" />

  </Context>

  方式三:在配置虚拟目录时,也就是在配置conf下面的server.xml时,在context标签内改成如下形式:

  <Context path="/WebRoot" reloadable="true" docBase="E:/workspace/DataSource/WebRoot" >

   <Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource"

   maxActive="50" maxIdle="30" maxWait="10000" logAbandoned="true"

   username="root" password="111111" driverClassName="com.mysql.jdbc.Driver"

   url="jdbc:mysql://localhost:3306/testdb" />

  </Context>

  配置文件中Resource标签中各属性的含义:

  driverClassName - JDBC 所用到的数据库驱动的类全名.

  maxActive - 连接池在同一时刻内所提供的最大活动连接数。

  maxIdle - 连接池在空闲时刻保持的最大连接数.

  maxWait - 当发生异常时数据库等待的最大毫秒数 (当没有可用的连接时).

  password - 连接数据库的密码.

  url - 连接至驱动的URL. (为了向后兼容, DRIVERNAME也被允许.)

  user - 数据库用户名.

  各种配置方式的范围也应该是不一样的。我在这就不细说了,总之就是在Context标签下面配置个Resource标签即可。

  测试代码:

  Context initContext = new InitialContext();

  Context envContext = (Context)initContext.lookup("java:/comp/env");

  DataSource ds = (DataSource)envContext.lookup("jdbc/test");

  System.out.println(ds.getConnection());

  打印出来不是null应该就成功了。

  注意,测试的时候要在tomcat内测试,也就是要在TOMCAT这个容器内(不要闲麻烦,写个简单的JSP页面测下,用个<%...%>就可以了,相当简单的)。不在tomcat这个容器里面测,会抛异常:

  ... javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

1. tomcat中添加jndi数据源,修改server.xml文件中<Context>标签的内容,如下所示

Xml代码



<Context docBase="TestDevon" path="/TestDevon"

reloadable="true" source="org.eclipse.jst.j2ee.server:TestDevon">

<Resource auth="Container" name="jdbc/mysql" type="javax.sql.DataSource" />

<ResourceParams name="jdbc/mysql">

<parameter>

<name>maxWait</name>

<value>5000</value>

</parameter>

<parameter>

<name>maxActive</name>

<value>20</value>

</parameter>

<parameter>

<name>factory</name>

<value>

org.apache.commons.dbcp.BasicDataSourceFactory

</value>

</parameter>

<parameter>

<name>url</name>

<!-- value>jdbc:derby://localhost:1527/devonoffice?characterEncoding=euckr</value-->

<value>

jdbc:mysql://localhost:3306/testdevon?autoReconnect=true

</value>

</parameter>

<parameter>

<name>driverClassName</name>

<value>

com.mysql.jdbc.Driver

</value>

</parameter>

<parameter>

<name>maxIdle</name>

<value>10</value>

</parameter>

<parameter>

<name>username</name>

<value>root</value>

</parameter>

<parameter>

<name>password</name>

<value>lgcnschina</value>

</parameter>

</ResourceParams>

</Context>

<Context docBase="TestDevon" path="/TestDevon"
reloadable="true" source="org.eclipse.jst.j2ee.server:TestDevon">
<Resource auth="Container" name="jdbc/mysql" type="javax.sql.DataSource" />
<ResourceParams name="jdbc/mysql">
<parameter>
<name>maxWait</name>
<value>5000</value>
</parameter>
<parameter>
<name>maxActive</name>
<value>20</value>
</parameter>
<parameter>
<name>factory</name>
<value>
org.apache.commons.dbcp.BasicDataSourceFactory
</value>
</parameter>
<parameter>
<name>url</name>
<!-- value>jdbc:derby://localhost:1527/devonoffice?characterEncoding=euckr</value-->
<value>
jdbc:mysql://localhost:3306/testdevon?autoReconnect=true
</value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>
com.mysql.jdbc.Driver
</value>
</parameter>
<parameter>
<name>maxIdle</name>
<value>10</value>
</parameter>
<parameter>
<name>username</name>
<value>root</value>
</parameter>
<parameter>
<name>password</name>
<value>lgcnschina</value>
</parameter>
</ResourceParams>
</Context>

2. 确认MySql驱动是否存放在tomcat下的common/lib文件夹中

3. 测试数据源的配置是否成功

(1) 在web.xml中添加如下代码

Xml代码



<resource-ref>

<description>DataSource</description>

<res-ref-name>jdbc/mysql</res-ref-name>

<res-type>javax.sql.DataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

<resource-ref>
<description>DataSource</description>
<res-ref-name>jdbc/mysql</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

(2) 测试数据源

Java代码



<html>

<head>

<title>test jndi</title>

</head>

<body>

<%

Context initCtx = new InitialContext();

Context ctx = (Context) initCtx.lookup("java:comp/env"); DataSource ds = (DataSource) ctx.lookup("jdbc/mysql");

Connection conn = ds.getConnection();

Statement stmt = conn.createStatement();

ResultSet rs = stmt.executeQuery("select * from user_info");

while (rs.next()) {

%>

<%=rs.getInt(1)%>

<%

}

rs.close();

stmt.close();

conn.close();

%>

</body>

</html>

<html>
<head>
<title>test jndi</title>
</head>
<body>
<%
Context initCtx = new InitialContext();
Context ctx = (Context) initCtx.lookup("java:comp/env"); DataSource ds = (DataSource) ctx.lookup("jdbc/mysql");
Connection conn = ds.getConnection();
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("select * from user_info");
while (rs.next()) {
%>
<%=rs.getInt(1)%>
<%
}
rs.close();
stmt.close();
conn.close();
%>
</body>
</html>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: