每个线程的新连接实例的连接池(JDBC)

时间:2010-08-22 09:36:28

标签: java multithreading jdbc connection-pooling

我正在创建一个多线程应用程序。但是,当我有一个为所有线程提供服务的连接对象时,我的应用程序遇到了许多意外行为。

我处于两难境地。我应该让每个线程创建,使用和处置自己的连接对象,还是应该使用连接池?

我尝试了连接池,使应用程序痛苦地淋浴。但是,我的直觉是,如果我让每个线程都创建自己的连接对象,我可能会遇到“连接太多”错误。

如果有任何方法可以帮助我,请告诉我。

问候。

1 个答案:

答案 0 :(得分:5)

无论线程问题如何,您都应明确寻找连接池。它将大大提高连接性能。然后到线程问题,这确实是一个主要问题。正常的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) {}
    }
}