(1).不管是tomcat5 还是tomcat6 ,都首先找到Tomcat目录下面的conf目录中的server.xml文件.
找到<GlobalNamingResources> </GlobalNamingResources>这对标签.
将这样的一段配置加到标签中间.
<Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/test?autoReconnect=true" maxActive="50" maxldle="10" maxWait="5000" username="root" password="admin" />
当然,样例是使用 MYSQL配置, 根据不同的需要,将url,driverClassName,username,passsword等参数改变就行.
然后再找到和server.xml同目录下面的context.xml文件.
在<Context></Context>标签中添加如下配置.
<ResourceLink global="jdbc/TestDB" name="jdbc/TestDB" type="javax.sql.DataSource"/>
global="jdbc/TestDB" 中的参数值("jdbc/TestDB")必须和上一段<Resource >配置中的name属性的值保持一样.
name="jdbc/TestDB" 这个可以随便取,但是在程序中调用的时候,就应该与name的值保持一致.
到这里,连接池已经配置好啦.
写个jsp测试吧:
在这ds =(DataSource)initCtx.lookup("java:comp/env/jdbc/TestDB");这句代码中的jdbc/TestDB必须和
<ResourceLink global="jdbc/TestDB" name="jdbc/TestDB" ........ />中的name 属性保持一样.
"lookup("java:comp/env/..."这都是固定写法.
2. 应该算是局部的连接池的配置吧.(针对工程而言)
不推荐在server.xml中进行配置,而是在context.xml中进行配置才是更好的方法。是站点目录下的context.xml文件,不是tomcat_home\conf下的。tomcat_home\webapps\yourApp\META-INF\context.xml
本身我们的工程中META-INF 中,没有context.xml文件,
例如 :E:\apache-tomcat-5.5.16\webapps\myproj\META-INF\
此时我们可以在META-INF目录下面新建一个context.xml文件.
里面写下如下的配置,具体的配置参数,按需改变.
<?xml version="1.0" encoding="UTF-8"?> <Context reloadable="true" crossContext="true"> <Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/test?autoReconnect=true" maxActive="50" maxldle="10" maxWait="5000" username="root" password="admin" /> </Context>
这样子,连接池,也就配置好啦,并不需要修改tomcat里面的文件。仅仅在我们的工程中的META-INF目录加入一个context.xml配置文件就好啦.换tomcat版本,更容易.
使用时如果项目中有Spring文件,则Spring的配置文件可以改成:
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName">
<value>java:comp/env/jdbc/default</value>
</property>
</bean>