配置tomcat下的连接池

    配置tomcat下的连接池说实话是个即简单又复杂的过程,我在配置过程中先后遇到了至少3种以上奇怪的错误,现总结经验,把配置过程总结如下:

1、配置%tomcat_home%/conf/Catalina/localhost/xxx.xml文件,其中xx代表你的web应用目录,缺省是ROOT

5.0.x

<?xml version='1.0' encoding='utf-8'?>
<Context displayName="Welcome to Tomcat" docBase="D:/JAVA/ROOT" path="" workDir="work/Catalina/localhost/_">
  <Resource auth="Container" description="DB Connection" name="jdbc/WebDB" type="javax.sql.DataSource"/>
  <ResourceParams name="jdbc/WebDB">
    <parameter>
      <name>factory</name>
      <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>

    <parameter>
      <name>maxActive</name>
      <value>100</value>
    </parameter>

       <parameter>
      <name>maxIdle</name>
      <value>30</value>
    </parameter>

    <parameter>
      <name>maxWait</name>
      <value>10000</value>
    </parameter>

    <!-- MySQL dB username and password for dB connections  -->
    <parameter>
     <name>username</name>
     <value>sa</value>
    </parameter>
    <parameter>
     <name>password</name>
     <value>asdfgyuiop</value>
    </parameter>

    <parameter>
       <name>driverClassName</name>
       <value>org.gjt.mm.mysql.Driver</value>
    </parameter>
     -->

    <parameter>
       <name>driverClassName</name>
       <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>
    </parameter>
    
    <parameter>
      <name>url</name>
      <value>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=WebDB</value>
    </parameter>
  </ResourceParams>
</Context>

5.5.x

 <Resource
    name="jdbc/XXX"
    type="javax.sql.DataSource"
    password="password"
    driverClassName="oracle.jdbc.driver.OracleDriver"
    maxIdle="2"
    maxWait="5000"
    username="username"
    url="jdbc:oracle:thin:@localhost:1521:SID"
    maxActive="4"/>

如果版本有所不同,请参阅%tomcat_home%/webapps/tomcat-docs/目录下的文档jndi-datasource-examples-howto.html

注意,我们不是去修改%tomcat%/conf/server.xml(通过admin加的连接池会自动把配置加到这个全局文件下),而是把配置单独加到对应的应用中;另外,如果你不是缺省的ROOT应用,应该修改path属性的值,使之与docBase匹配,例如如果docBase="D:/JAVA/haina",则path应为 path="/haina"

2、配置%app_base%/WEB-INF/web.xml(此步骤为大多数文章推荐,经过测试证明可以不用)

在</web-app>前加上这样一段

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

3、访问的程序中要有"java:comp/env"前缀

源码如下:

  Context initCtx = new InitialContext();
  ctx = (Context) initCtx.lookup("java:comp/env");
  ds = (DataSource)ctx.lookup("jdbc/WebDB");
  cn = ds.getConnection();

4、数据库如果是MS SQL Server 2000,而操作系统是Windows XP或Windows 2003的话,需要给MS SQL Server 2000打上sp3以上的补丁

总结:以上步骤均十分关键,如果有误对应错误如下

1、第一步错误,报错

org.apache.commons.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'

2、第三步错误,报错

javax.naming.NameNotFoundException: Name jdbc is not bound in this Context

3、第四步错误,报错

java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Error establishing socket

如果有上述错误,请检查对应步骤是否正确实施

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值