我尝试让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"
...
答案 0 :(得分:4)
Tomcat使用工厂来创建JNDI资源。对于有限数量的资源类型(包括javax.sql.DataSource),Tomcat知道它可以使用内置工厂。对于未知资源类型(例如jcom.jolbox.bonecp.BoneCPDataSource),您需要指定用于创建资源的工厂。