每个线程的HikariCP多线程单独连接

问题描述 投票:11回答:1

向stackoverflow社区的人们。我一直在寻求与HikariCP连接池相关的问题的帮助。

高级:我正在尝试使用线程池创建多个线程,我的计划是为每个工作线程提供与HikariCP自己的独立连接,但是HikariCP所做的是它在多个线程之间共享一个公共连接。我正在使用

public synchronized Connection getConnection() throws SQLException
{
  synchronized (dataSource) {
  return dataSource.getConnection();
  }
}

检索数据库连接。现在,当我关闭一个连接时,我看到其他线程中的问题说该连接已关闭,并且该线程正在处理的记录批次被丢弃。

这是我的日志文件中的stmts:

2016-06-08 11:52:11,000 DEBUG [com.boxer.delete.SmartProcessWorker] (pool-1-thread-6:) Closing DB connection ConnectionJavassistProxy(1551909727) wrapping oracle.jdbc.driver.T4CConnection@7b4f840f
2016-06-08 11:52:11,002 DEBUG [com.boxer.delete.SmartProcessWorker] (pool-1-thread-9:) Closing DB connection ConnectionJavassistProxy(1511839669) wrapping oracle.jdbc.driver.T4CConnection@343b8714
2016-06-08 11:52:11,014 ERROR [com.boxer.delete.SmartProcessWorker] (pool-1-thread-5:) SQLException trying to Execute pstmt batch
2016-06-08 11:52:11,014 ERROR [com.boxer.delete.SmartProcessWorker] (pool-1-thread-5:) Connection is closed
java.sql.SQLException: Connection is closed
        at com.zaxxer.hikari.proxy.ConnectionProxy.checkClosed(ConnectionProxy.java:275)
        at com.zaxxer.hikari.proxy.ConnectionJavassistProxy.commit(ConnectionJavassistProxy.java)
        at com.boxer.delete.SmartProcessWorker.processRecords(SmartProcessWorker.java:219)
        at com.boxer.delete.SmartProcessWorker.run(SmartProcessWorker.java:174)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at java.lang.Thread.run(Thread.java:745)

现在,有人可以帮助我解决如何从hikari数据源获取Db连接的问题,而该连接显然没有被任何其他线程共享?

multithreading concurrency database-connection connection-pooling hikaricp
1个回答
0
投票

简短的答案:不要那样做。 JDBC连接不打算在线程之间共享。

来自HikariCP(source)的作者:

在JDBC中已弃用对连接的多线程访问,并且没有也受HikariCP支持。

HikariCP足够快,您可以获得连接,执行SQL,然后将其返回池中多次请求。

最佳做法是仅将连接保存在局部变量中,最好放在try-with-resources块中,或者可能传递给堆栈,但绝不在类成员字段中。如果遵循这种模式几乎不可能泄漏连接或意外共享跨线程。

© www.soinside.com 2019 - 2024. All rights reserved.