欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

netty报错:io.netty.util.internal.OutOfDirectMemoryError: failed to allocate ...

程序员文章站 2022-05-04 16:55:01
...

io.netty.util.internal.OutOfDirectMemoryError: failed to allocate …

上周出现一个问题,一个netty程序在运行几个小时候就出现了这种情况,内存满了,后来经过排查发现了这个问题:

  • 如果出现这个问题,请看看你的diamante中是否出现了这样创建ByteBuf的情况:
ByteBuf byteBuf = Unpooled.directBuffer();

当你使用此方法进行创建ByteBuf时,创建的是堆外内存,gc不能将其回收,所以会导致内存不断上涨,最终导致内存溢出。

解决办法

  • 创建directBuffer省去了数据到内核的拷贝,因此效率相对较高,但是要学习如何使用,使用过后一定要及时回收:release()掉
byteBuf.release();