使用ProtoBuf通讯协议完成netty文件传输的时候遇到了内存直接溢出(OutOfDirectMemoryError)问题,在网上搜寻了很多,发现有讲到关于ByteBuf的手动回收,即每次使用之后relese(),但是我现在使用的是ProtoBuf生成的java对象,其类型并非ByteBuf,但是我又在ProtoBuf生成的java对象中存储了Byte数组类型的字段,我猜测可能是因为这个数据没有被回收导致的内存直接溢出,想请问该如何解决?
Netty中的ProtoBuf类型的对象是由JVM的垃圾回收器来回收的。可以尝试使用工具先诊断内存具体泄漏点,例如jmap、jstack等,或者调整Netty的内存配置参数,例如maxMessagesPerRead、maxCachedBufferCapacity。
不知道你这个问题是否已经解决, 如果还没有解决的话:定义序列化与反序列化规则,方法。
具体方法:
channelbuffer
没有 string 对象 ,因为长度可变,所以预定义它的长度。
反序列化:先看长度字段然后在读取对象。