Netty中处理写序列化异常
writeAndFlush之后既不能在inbound的exceptionCaught也不能在outputbound的exceptionCaught中拿到异常(这两个应该仅仅处理channelRead,channelWrite的异常),正确的方法是使用addListener中的回调:
ChannelFuture f = ctx.writeAndFlush(response);
f.addListeners(ChannelFutureListener.FIRE_EXCEPTION_ON_FAILURE);
但默认的exceptionCaught仅仅会打出日志,不会关掉channel,所以通常还须要加上exceptionCaught。
exceptionCaught默认是从head往tailf方向传,所以仅仅须要在最后那个handler加exceptionCaught,假设非要精确在某个handler抛错,能够自己定义个listener。
而像inbound的错误,通常在相应的handler exceptionCaught能够捕捉到。