ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

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

2019-10-09 01:12:36  阅读:156  来源: 互联网

标签:java multithreading jdbc connection-pooling


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

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

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

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

问候.

解决方法:

无论线程问题如何,您都应该选择连接池.它将大大提高连接性能.然后到线程问题,这确实是一个主要问题.普通的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) {}
    }
}

标签:java,multithreading,jdbc,connection-pooling
来源: https://codeday.me/bug/20191009/1875693.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有