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