異常信息
io.netty.util.IllegalReferenceCountException: refCnt: 0, decrement: 1
原因
handler 繼承了 SimpleChannelInboundHandler,SimpleChannelInboundHandler 中 channelRead 代碼如下:
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
boolean release = true;
try {
if (this.acceptInboundMessage(msg)) {
this.messageReceived(ctx, msg);
} else {
release = false;
ctx.fireChannelRead(msg);
}
} finally {
if (this.autoRelease && release) {
ReferenceCountUtil.release(msg);
}
}
}
在 finally 代碼塊中釋放了 msg
解決方案
handler 改繼承 ChannelHandlerAdapter