netty异常处理机制
所属分类 netty
浏览量 1556
入站 出站异常处理
入站异常处理
默认的ChannelHandler#exceptionCaught 把异常传给管道中的下一个处理器
如果一个异常到达了管道的尾部,被记录为未被处理 记录 warning 日志
自定义处理,重写exceptionCaught方法,直接处理掉异常或继续传播
public class InboundExceptionHandler extends ChannelInboundHandlerAdapter {
@Override
public void exceptionCaught(ChannelHandlerContext ctx,Throwable cause) {
cause.printStackTrace();
ctx.close();
}
}
InboundExceptionHandler 放到 pipeline最后,确保入站的所有异常都会被处理
public interface ChannelInboundHandler extends ChannelHandler
void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception;
The exceptionCaught() method is only invoked for exceptions from inbound events like channelRead(), channelActive() etc.
出站异常处理
出站 I/O 操作 返回一个 ChannelFuture
几乎所有的ChannelOutboundHandler都会传递一个ChannelPromise实例,
作为ChannelFuture的子类,它也可以被监听器管控来获取异步通知,但是ChannelPromise为实时通知提供可写的方法
setSuccess setFailure
public interface ChannelPromise extends ChannelFuture, Promise< Void>
@Override
ChannelPromise setSuccess(Void result);
ChannelPromise setSuccess();
@Override
ChannelPromise setFailure(Throwable cause);
上一篇
下一篇
netty 服务端启动日志
springboot应用安全防护
netty ChannelFuture 实例
Garbage Collection Roots
内存分析工具MAT中的重要概念
获取jvm heap dump 的几种方式