最近weblogic用的起来老是数据库连接池被耗尽

只要connection没有被close就一定会发生connection leak。先前我对此也是笃信不疑。直到有一次我在作系统压力测试时碰巧发现没有close掉的connection居然没发生leak,这让我很吃惊。于是专门做了一个实验来验证没有close的connection是否可以被GC回收。下面就把这个简单的试验说一下:

先写一个很简单的jsp,从pool中申请connection,把申请出的connection存放在jsp的局部变量中,用完后不关它。然后用类似LR压力测试工具录制一段简单脚本,制造若干并发去访问这个页面,或者干脆就使劲刷新这个jsp,然后观察WLS connection pool的状态,看看connection是不是一会就分配不出来了?答案是,connection pool没发生leak,connection一直可以从pool中申请出来。

让我们分析一下,为什么connection没有发生leak。
当GC发现connection对象已经没有被别的对象引用时,就把它当“垃圾”回收了。在connection被destroy掉的时候,应该是connection的finalize方法对connection是否close做了判断,如果没有close,那就close这个connection,于是pool回收了这个Connection。

由于不清楚WebLogic关于Connection pool的实现机制,上述connection回收过程的具体流程实属臆测,但有一点可以肯定,connection确实是被pool回收了。

做完这个实验很惭愧,惭愧的是把SUN和BEA想的太简单了,其实BEA聪明的利用了看似很傻的GC实现了资源的回收,呵呵。


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值