Netty ProtoBuf类型的对象怎么回收

使用ProtoBuf通讯协议完成netty文件传输的时候遇到了内存直接溢出(OutOfDirectMemoryError)问题,在网上搜寻了很多,发现有讲到关于ByteBuf的手动回收,即每次使用之后relese(),但是我现在使用的是ProtoBuf生成的java对象,其类型并非ByteBuf,但是我又在ProtoBuf生成的java对象中存储了Byte数组类型的字段,我猜测可能是因为这个数据没有被回收导致的内存直接溢出,想请问该如何解决?

Netty中的ProtoBuf类型的对象是由JVM的垃圾回收器来回收的。可以尝试使用工具先诊断内存具体泄漏点,例如jmap、jstack等,或者调整Netty的内存配置参数,例如maxMessagesPerRead、maxCachedBufferCapacity。

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^