java—每个线程在新连接示例上的连接池(jdbc)

nkkqxpd9  于 2021-06-26  发布在  Impala
关注(0)|答案(1)|浏览(405)

我正在创建一个多线程应用程序。然而,当我有一个连接对象服务于所有线程时,我在应用程序中遇到了很多意想不到的行为。
我进退两难。我应该让每个线程创建、使用和处理自己的连接对象,还是应该使用连接池?
我尝试了连接池,这使应用程序痛苦地淋浴。然而,我的直觉是,如果我让每个线程创建自己的连接对象,我可能会得到一个“连接太多”的错误。
请让我知道,如果有任何方法来帮助这一点。
当做。

628mspwn

628mspwn1#

不管线程问题如何,您都应该选择连接池。它将大大提高连接性能。对于线程问题,这确实是一个主要问题。正常的jdbc习惯用法是在尽可能短的范围内获取并关闭所有资源。i、 所有这些都应该发生在同一个方法块中。您描述的问题症状证实您没有正确关闭这些资源。
无论连接是否来自池,都应始终关闭。关闭一个非池连接将防止它在数据库打开太长时间后超时。关闭池连接实际上会将其释放回池并使其可用于下一次租用。
对于一个 INSERT .

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) {}
    }
}

相关问题