使用bonecp作为Tomcat 5.5数据源

时间:2012-03-28 10:45:16

标签: tomcat jndi tomcat5.5 bonecp

我尝试让Tomcat将BoneCP用作连接池,因为DBCP在这里无法正常工作。

我尝试将它添加到定义我的webapp的context.xml中,如下所示:

<Context path="/reports" privileged="true" crossContext="true">

    <Resource name="jdbc/IKOffice"
          type="com.jolbox.bonecp.BoneCPDataSource"
          auth="Container"

          username="ik"
          password="******"
          jdbcUrl="jdbc:postgresql://localhost:5434/IKOffice_Core"

          lazyInit="true"
          partitionCount="1" 
          ... more properties ...
          logStatementsEnabled="false" />

</Context>

但是当我尝试访问资源时,它总是说:

javax.naming.NamingException: Cannot create resource instance

日志文件中没有错误,所有必需的jar都可用于webapp。这是怎么回事?

当我使用这样的资源时,一切都有效:

     <Resource name="jdbc/IKOffice"
          auth="Container"
          type="javax.sql.DataSource"
          username="ik"
          password="******"
          driverClassName="org.postgresql.Driver"
          url="jdbc:postgresql://localhost:5434/IKOffice_Core"
          maxActive="8"
          maxIdle="4" />

SOLUTION:

您必须指定BeanFactory,如下所示(第3行):

 <Resource name="jdbc/IKOffice"
          type="jcom.jolbox.bonecp.BoneCPDataSource"
          factory="org.apache.naming.factory.BeanFactory"
          auth="Container"
          ...

1 个答案:

答案 0 :(得分:4)

Tomcat使用工厂来创建JNDI资源。对于有限数量的资源类型(包括javax.sql.DataSource),Tomcat知道它可以使用内置工厂。对于未知资源类型(例如jcom.jolbox.bonecp.BoneCPDataSource),您需要指定用于创建资源的工厂。