使用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。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 宇视监控服务器无法登录
- ¥15 PADS Logic 原理图
- ¥15 PADS Logic 图标
- ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
- ¥15 DruidDataSource一直closing
- ¥20 气象站点数据求取中~
- ¥15 如何获取APP内弹出的网址链接
- ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
- ¥50 STM32单片机传感器读取错误
- ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据