使用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 Stata链式中介效应代码修改
- ¥15 latex投稿显示click download
- ¥15 请问读取环境变量文件失败是什么原因?
- ¥15 在若依框架下实现人脸识别
- ¥15 添加组件无法加载页面,某块加载卡住
- ¥15 网络科学导论,网络控制
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错