Netty 的内存泄漏问题

本文详细介绍了在使用Netty进行客户端与服务端通信时,由于客户端使用同步I/O (bio) 而服务端使用非阻塞I/O (nio) 导致内存泄露的问题。通过分析原因,提出了解决方案:在客户端启动一个线程读取发送的数据,从而避免内存积累过载,最终使Java堆区的旧代区域趋于稳定。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、记录一种内存泄漏的引起原因,本宝宝用的netty5.x开发;通信模式是client端发消息过来,netty服务端读出并在控制台打出来并且发送一段message过去,结果内存直接爆满了。不讲过多悬念,就是因为netty是使用的nio而,client端是使用的bio,nio发送数据发送到缓冲区,但client端是同步的但没有读取数据,导致nio一直将数据缓存到内存里面,搞一阵子之后,报oom。后来启动一个线程将发过去的数据读出来了,然后java 堆old区在回收之后趋于稳定

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值