【第22篇】Netty解码器剖析与入站出站处理器
2019-06-03 本文已影响2人
爱学习的蹭蹭
Netty的处理器重要概念
- 1、Netty的处理器可以分为两大类:入站处理器与出站处理器
- 2、入站处理器的顶层是ChannelInboundHandler,而出站处理器的顶层是ChannelOutboundHandler
- 3、数据处理器时常用的各种编解码,本质上都是处理器
- 4、编解码器:物流我们向网络希尔的数据是什么类型(int,char,String 二进制等)数据在网络传递时候,其都是以字节流的形式呈现的,将数据由原本的形式转换为字节流的操作成为编码encode,将数据由字节流转换成原本的格式或是其他格式的操作称为解码(decode),编解码统称为codec
- 5、编码:本质上是一种出站的处理器,因此一定是ChannelOutboundHandler
- 6、解码:本质上是一种入站的处理器,因此一定是ChannelInboundHandler
- 7、在Netty中,编码器通常以XXXEncoder命名,解码器通常以XXXDecoder命名
*入站处理器代码使用如:
public class MyServerHandler extends SimpleChannelInboundHandler<String> {
@Override
protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
System.out.println(ctx.channel().remoteAddress() + ", " + msg);
ctx.channel().writeAndFlush("from server: " + UUID.randomUUID());
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
cause.printStackTrace();
ctx.close();
}
}
SimpleChannelInboundHandler
ChannelInboundHandler
ChannelOutboundHandler
关于Netty编解码的重要结论
- 1、无论是编码器还是解码器,其所接收的消息类型,必须要与待处理的参数类型一致,否则该编码器或解码器并不会被执行
- 2、在解码器进行数据解码时候,一定要记得判断(ByteBuf)中的数据是否足够,否则将会产生一些问题
组合方式管理通道句柄
- CombinedChannelDuplexHandler,从代码里面看出来,它基础ChannelDuplexHandler管道,此类有诸多重要的方法如:
bind
,channelRead
,
connect
、disconnect
、deregister
,而它有一个内部类DelegatingChannelHandlerContext,它也有比较多重要的方法,如:alloc
,attr
,bind
这里不写了,请看【DelegatingChannelHandlerContext方法】截图
DelegatingChannelHandlerContext方法DelegatingChannelHandlerContext方法