netty和jvm 虚拟机参数的 XX:+DisableExplicitGC 注意事项

在使用netty时,经常出现内存溢出,经查询是这个坑:

netty 使用的nio 和 jvm 中的 XX:+DisableExplicitGC配置的冲突导致的,具体经过:nio 使用直接内存区域  Direct Memory内存回收和其他内存回收有点区别。Java堆内放置的是direct memory 引用,正常情况下当在young gc 的时候会把这个已死的引用回收,进而也回收了native memory 区域 , 但是有些移动到old gen区中的,在没有发生full gc时候这个对象一直没有被回收,然后direct memory 应该会累积。

另外当在为DirectByteBuffer分配空间过程中发现直接内存不足时会显式调用System.gc(),以期通过full GC来强迫已经无用的DirectByteBuffer对象释放掉它们关联的native memory , 这个可以从java.nio的源码中可以分析到(DirectByteBuffer .class Bits.class)

 

java内存区域理解

http://iamzhongyong.iteye.com/blog/1333100

转载于:https://www.cnblogs.com/fypy/p/8252909.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值