Java连接池

https://blog.youkuaiyun.com/persistencegoing/article/details/84376427

 

Java连接池过程:

   数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量﹑使用情况,为系统开发﹑测试及性能调整提供依据。

 

为什么使用连接池:

        数据库连接是非常占用资源的,也是一件费时的操作,尤其是在高并发的情况下,如果每次都去建立数据库连接就会有性能问题,也会影响一个应用程序的延展性。数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。

 

 

让我们来看看一个典型的数据库连接请求的底层途径。

  • Java 应用程序调用 getConnection()
     
  • JDBC 厂商代码(驱动程序或者 DataSource 实现)请求一个来自 JVM 的套接字连接。
     
  • JVM 需要检查底层调用的安全方面。例如,applet 只被允许和产生它们的服务器进行通讯。
     
  • 如果允许,调用需要穿过主机网络接口到公司 LAN 上。
     
  • 调用可能需要穿过防火墙到达因特网或广域网。
     
  • 调用最终到达目的子网络,在那里它可能需要穿过另一个防火墙。
     
  • 调用到达数据库主机。
     
  • 数据库服务器处理新的连接请求。
     
  • 许可证服务器可能需要查询来确定是否有适当的许可。
     
  • 数据库初始化新的客户机连接,包括所有内存和操作系统开销。
     
  • 返回调用被送回 JDBC 客户机(在那里它必须穿过所有防火墙和路由器)。
     
  • JVM 收到返回调用,然后创建适当的 Connection 对象。
     
  • 请求的 Java 应用程序收到 Connection 对象。

 

 

 

另外Druid连接池对数据库的监控做的很好,可以详细统计SQL执行的性能。

 

 

希望大家关注我一波,防止以后迷路,有需要的可以加群讨论互相学习java ,学习路线探讨,经验分享与java求职     

群号:721 515 304

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值