Netty资源泄露检测ResourceLeakDetector

本文介绍了Netty中的资源泄露检测机制,包括检测原理、检测级别和使用配置。当ByteBuf不再使用且未调用release时,可能导致资源泄露。检测原理依赖于虚引用,若未释放ByteBuf,GC会将虚引用对象加入到ReferenceQueue,从而检测到内存泄露。通过配置参数`io.netty.leakDetectionLevel`可设置检测级别。
摘要由CSDN通过智能技术生成

资源泄露

  ByteBuf不再使用后(没有引用),没有调用release,导致ByteBuf资源一直被占用无法回收。

检测原理

原理:每次创建ByteBuf时,创建一个虚引用对象A指向该ByteBuf对象,如果正常调用release()操作,则虚引用对象A和ByteBuf对象均被回收;如果ByteBuf对象不再使用(没有其他引用)但没有调用release()操作,则GC时虚引用对象A被加入ReferenceQueue中,通过判断队列是否为空,即可知道是否存在内存泄露。

一、创建ByteBuf的逻辑:

protected ByteBuf newDirectBuffer(int initialCapacity, int maxCapacity) {
        PoolThreadCache cache = threadCache.get();
        PoolArena<ByteBuffer> directArena = cache.directArena;

        final ByteBuf buf;
        if (directArena !=
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值