码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2018-01-09 20:22:55      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:nbsp   情况下   log   data-   byte   sys   ack   bit   回收   

在使用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)

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

标签:nbsp   情况下   log   data-   byte   sys   ack   bit   回收   

原文地址:https://www.cnblogs.com/fypy/p/8252909.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!