Violetttte 2023-03-29 23:08 采纳率: 82.8%
浏览 23
已结题

Netty ProtoBuf类型的对象怎么回收

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

  • 写回答

2条回答 默认 最新

  • Java码库 2023-03-29 23:22
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月8日
  • 已采纳回答 3月31日
  • 创建了问题 3月29日