使用bonecp作为Tomcat 5.5数据源

我尝试让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" />

解:

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

 <Resource name="jdbc/IKOffice"
          type="jcom.jolbox.bonecp.BoneCPDataSource"
          factory="org.apache.naming.factory.BeanFactory"
          auth="Container"
          ...
最佳答案
Tomcat使用工厂来创建JNDI资源.对于有限数量的资源类型(包括javax.sql.DataSource),Tomcat知道它可以使用内置工厂.对于未知资源类型(例如jcom.jolbox.bonecp.BoneCPDataSource),您需要指定用于创建资源的工厂.

转载注明原文:使用bonecp作为Tomcat 5.5数据源 - 代码日志