java堆外内存泄漏

在压力测试中,一个使用JDK1.6的系统内存从20%升至100%,并发300人时TPS降低。通过排查发现并非由DirectByteBuffer引起,而是Java的GZIP解压缩导致。使用google-perftools分析,发现`Java_java_util_zip_Inflater_init`函数导致内存分配。解决方案包括升级JDK到7u71和限制GZIP解压缩的使用,避免大并发时内存泄漏。
摘要由CSDN通过智能技术生成

问题描述

最近有个系统在做压力测试,

环境配置:

4核CPU 8g内存 jdk1.6.0_25,jvm配置-server -Xms2048m -Xmx2048m 

出现问题如下

执行并发300人,压测持续1个小时内存使用率从20%上升到100%,tps从1100多降低到600多。

排查过程

top命令查看内存占用如下


然后查看java堆内存分布情况

Java堆外内存泄露是指在使用Java NIO进行堆外内存分配时,由于程序逻辑或代码问题导致堆外内存没有得到正确的释放,从而导致占用的内存越来越多,最终导致内存泄露。 下面是一些可能导致Java堆外内存泄露的原因和解决方案: 1. 内存分配和释放不匹配。在使用Java NIO进行堆外内存分配时,需要及时释放内存,否则会导致内存泄露。解决方法是确保内存分配和释放匹配,特别是在使用DirectByteBuffer分配堆外内存时,需要显式地调用ByteBuffer的clear()或compact()方法释放内存。 2. 使用ByteBuffer时没有适当的缓冲区管理。当使用ByteBuffer时,需要及时刷新缓冲区,否则会导致内存泄露。解决方法是及时刷新缓冲区,例如使用ByteBuffer的flip()方法刷新缓冲区。 3. 内存泄露分析工具不够好。目前有很多内存泄露分析工具,但是并不是所有工具都能准确地检测Java堆外内存泄露。解决方法是选择一款专门针对Java堆外内存泄露的工具进行分析。 4. 不合理的内存分配策略。在使用Java NIO进行堆外内存分配时,需要注意内存分配策略,例如一次分配太多内存可能会导致内存泄露。解决方法是根据实际情况选择合适的内存分配策略,例如分段分配内存等。 希望这些解决方案能帮助您解决问题。如果仍然存在问题,请提供更多详细信息,以便更好地了解问题并提供更好的建议。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值