Netty中处理写序列化异常

来源:互联网 发布:泰国旅游 知乎 编辑:程序博客网 时间:2024/06/05 11:05
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可以捕捉到。
0 0
原创粉丝点击