io.netty.util.internal.OutOfDirectMemoryError: failed to allocate …
上周出现一个问题,一个netty程序在运行几个小时候就出现了这种情况,内存溢出了:
io.netty.util.internal.OutOfDirectMemoryError: failed to allocate ...
后来经过排查发现了这个问题的原因:
- 如果出现这个问题,请看看你的代码中是否出现了这样创建ByteBuf的情况:
ByteBuf byteBuf = Unpooled.directBuffer();
当你使用此方法进行创建ByteBuf时,创建的是堆外内存,gc不能将其回收,所以会导致内存不断上涨,最终导致内存溢出。
解决办法
- 创建directBuffer省去了数据到内核的拷贝,因此效率相对较高,但是要学习如何使用,使用过后一定要及时回收:release()掉
byteBuf.release();