java游戏服务端mysql连接池_Java连接MySql用DBCP连接池的实现

DBCP1.4或1.6依赖的jar包

9b8e5de54a06cee61fa024b3399e8f21.png

DBCP参数说明

45e4c959259c2679a0a96cae19643327.png

ec5f8ee1049f2bbaffbad08473e3a753.png

d7e269ff792f007a905a91c1cab44bb1.png

代码

DBToolls.java文件

7ef2d51a2e4556b9e1f78e192ae5abde.png

db430706a84bf3c9a9403b8a1bcacf4b.png

测试test.java

b39047075aa871e9e79cdbc9299aade7.png

运行结果

5bb2981b415654593097e6c3d01e11c8.png

DBCP2以上版本依赖的jar包

08b93ae8139d33a5ca449085d89bbc2c.png

DBCP2配置详细说明

由于commons-dbcp所用的连接池出现版本升级,因此commons-dbcp2中的数据库池连接配置也发生了变化,具体的参数配置说明如下:

常用连接配置

71f161cb7c7d7458390466068fa0f239.png

数据源连接数量配置

7597b002bc0caae3195e209aafb04cf9.png

提示: 如果在高负载的系统中将maxIdle的值设置的很低,则你可能会发现在一个新的连接刚刚被创建的时候就立即被关闭了。这是活跃的线程及时关闭连接要比那些打开连接的线程要快,导致空闲的连接数大于maxIdle。高负载系统中maxIdle的最合适的配置值是多样的,但是缺省值是一个好的开始点。

事务属性配置

d22fe61b02396e98e2f0f4e867ec87ae.png

数据源连接健康状况检查

ed8de832325835d5f4bbf8c2edff76fa.png

0a27bf1da85743e862fc938d11f61ddf.png

缓存语句

5fde7d4deb99b099d5ef8461bcea50e6.png

这个设置同时作用于预处理语句池. 当一个可用的语句池被创建给每一个连接时,通过以下方法创建的预处理语句将被池化。

public PreparedStatement prepareStatement(String sql)

public PreparedStatement prepareStatement(String sql, int resultSetType, int resultSetConcurrency)

提示 -要确保你的连接会留下一些资源给其他语句。池化预处理语句可能会在数据库中保持他们的游标,可能会引起连接的游标越界,尤其是maxOpenPreparedStatements的值被设置为默认值(无限的),而且一个应用程序可能会为每个连接打开大量不同的预处理语句。为了避免这个问题maxOpenPreparedStatements应该被设置为一个小于连接可以打开的最大游标数的值。

37d0c36be415d3e9e8cfdfbd451b1811.png

如果允许访问的话,使用如下代码结构:

accefb4409a58f7a7edf62309f98b126.png

默认值为false,这是一个有着潜在风险的操作,使用不当可能会导致非常严重的后果。(在守护连接已被关闭的情况下,关闭底层连接或者继续使用它),只有在你需要直接访问驱动的特有扩展是可以谨慎使用。

NOTE: 除了最原始那个之外,不要关闭底层连接

7f531e3c9eb759637affacf266f331da.png

连接泄露回收

2f44f4e7af2b9bf59027ded63c57f3cd.png

代码

DB2.java文件

2c06ea9ae6200e7302e519367cc567f3.png

3783286ce0f225fb4456632088d7d3e2.png

test.java文件

3b1ab3e85f7067f233004b800b3fbea8.png

执行结果

2fd86904ab25bd70b5cc225f713b7d69.png

需要面试资料的加群748620413

本文分享 CSDN - 月云银。

如有侵权,请联系 support@oschina.cn 删除。

本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值