kafka 0.9版本堆外内存溢出

1、背景

线上kafka是0.9版本,最大堆内存1G。

从server.log看到,java.lang.OutOfMemoryError: Direct buffer memory,是堆外内存溢出了。

加大堆外内存,过一段时间还是堆外内存溢出。

2、原因分析

猜测应该是禁用了手动 GC 导致的,同事升级kafka版本到1.0,没有再重现过。

我看了kafka 0.9版本的启动脚本,确实禁用了手动GC(-XX:+DisableExplicitGC)。

申请堆外内存的时候,会调用System.gc();,-XX:+DisableExplicitGC 会导致 System.gc(); 失效,然后就内存溢出了。

参考链接

3、解决方案

a.升级kafka版本到1.0,

b.或者去掉-XX:+DisableExplicitGC,如果使用ConcurrentMarkSweep(CMS)垃圾回收器,可以改成 -XX:+ExplicitGCInvokesConcurrent,把FullGC变成并发的。

4、思考

kafka作为全球著名的开源软件,也存在过这样的问题,说明伟大的软件也是一步一步进化的。

勇敢的参与到开源大潮中去吧,我辈也可以添砖加瓦,并从中学习进步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值