每个线程的新连接实例的连接池(JDBC)
我正在创建一个multithreading应用程序。 但是,当我有一个为所有线程提供服务的连接对象时,我的应用程序遇到了很多意外行为。
我处于两难境地。 我应该让每个线程创建,使用和处置自己的连接对象,还是应该使用连接池?
我尝试过连接池,使应用程序痛苦地淋浴。 但是,我的直觉是,如果我让每个线程都创建自己的连接对象,我可能会遇到“连接太多”的错误。
如果有任何方法可以帮助我,请告诉我。
问候。
无论线程问题如何,您都应该选择连接池。 它将大大提高连接性能。 然后到线程问题,这确实是一个主要问题。 普通的JDBC习惯用法是在尽可能短的范围内获取和 关闭所有资源。 即所有这些都应该发生在同一个方法块中。 您描述的问题症状确认您没有正确关闭这些资源。
无论连接是否来自池,都应始终关闭。 关闭非池化连接将阻止数据库在长时间保持打开状态时超时。 关闭池连接实际上会将其释放回池中并使其可用于下一次租赁。
以下是INSERT
的正常JDBC习惯用法的样子。
public void create(Entity entity) throws SQLException { // Declare. Connection connection = null; PreparedStatement statement = null; try { // Acquire. connection = database.getConnection(); statement = connection.prepareStatement(SQL_CREATE); // Use. statement.setSomeObject(1, entity.getSomeProperty()); // ... statement.executeUpdate(); } finally { // Close. if (statement != null) try { statement.close(); } catch (SQLException logOrIgnore) {} if (connection != null) try { connection.close(); } catch (SQLException logOrIgnore) {} } }