我想升级一个GWT应用程序,以使用DBCP2而不是DBCP。配置部分运行良好,但我在控制台中看到了一个警告。
WARN [org.apache.commons.dbcp2.PoolingDataSource] PoolableConnectionFactory not linked to pool. Calling setPool() to fix the configuration.PersistenceManagerFactory是使用JDOHelper构建的,因此我无法访问DBCP2对象来设置池。我们用的是
JDOHelper.getPersistenceManagerFactory(properties)我在JDO类中执行了一些调试,发现即使引发警告,池实际上也被设置为连接工厂。请查找以下来自org.apache.commons.dbcp2.PoolingDataSource的代码
// Verify that _pool's factory refers back to it. If not, log a warning and try to fix.
if (pcf.getPool() != _pool) {
log.warn(Utils.getMessage("poolingDataSource.factoryConfig"));
@SuppressWarnings("unchecked") // PCF must have a pool of PCs
ObjectPool<PoolableConnection> p = (ObjectPool<PoolableConnection>) _pool;
pcf.setPool(p);
}有人知道使用JDOHelper正确处理2配置的方法吗?
发布于 2016-02-11 16:07:12
似乎是一些奇怪的DBCP2的事情,它应该做自己,但不是出于某种原因。在DataNucleus DBCP2连接器代码中
connectionPool = new org.apache.commons.pool2.impl.GenericObjectPool(poolableCF);我个人认为这足以让DBCP2知道池DBCP2库返回到poolableCF (即传入的内容),但是如果您这样做,它会给出这个日志消息。如果添加以下行
poolableCF.setPool(connectionPool);在他们的代码中,您马上就不会收到日志消息。也许你想把它贡献给DataNucleus项目?
https://stackoverflow.com/questions/35341760
复制相似问题