4.1 Channelhandler

4.1.1 Channel声明周期(状态事件)

方法 描述
ChannelUnregistered Channnel已创建,但是未注册到EventLoop
ChannelRegistered Channnel已注册到EventLoop
ChannelActive Channnel活动状态(已连接到远程节点),可以发送接收数据
ChannelInactive Channnel未连接到远程站点

4.1.2 Channelhandler生命周期(状态事件)

从channelPipeLine中添加删除时触发

方法 描述
handlerAdded 当把handler添加到channelPipieLine中时
handlerRemoved 从pipeLine中移除时
exceptionCaught handler处理过程中异常时调用

4.1.3 ChannelInBoundHandler接口--入站数据及状态变化

ChannelInBoundHandlerAdapter--调用read后如果不继续调用ctx.fireChannelRead(msg)将消息传给下一个channel(即丢弃消息),则需要手动释放(ReferenceCountutil.release(msg))

SimpleChannelInBoundHandler -- 已封装,自动释放资源

方法 描述
channelRead 从channel中读取数据时
channelReadComplete 所有数据都已从Channel中读取之后调用(可能之前channelRead已多次调用)
userEventTriggered 当ChannelInBoundHandler.fireuserEventTriggered()被调用时触发

4.1.3 ChannelOutBoundHandler 接口--出站数据及拦截操作

a). 可按需推迟操作或者事件.

b). 方法被channel、channelPipeLine及channelHandlerContext调用

方法 描述
bind
connect
disconnect
close
deregister
read(ChannelhandlerContext) 当请求从channel读取数据时调用
flush 写数据到远端
write write后不传递消息时需要手动释放,ReferenceCountutil.release(msg);promise.setSuccess();

4.2 ChannelPipeLine-channelhandler实例链

a). 可动态修改

b). fireChannelread之类方法都是调用ChannelPipeLine中下一个handler中对应方法.

方法 描述
addFist
addBefore
addAfter
addlast
remove
replace 以上都是处理内部channelHandler的方法

4.3 ChannelHandlerContext接口-handler和pipeLine之间的连接

4.4 异常处理

4.4.1 入站异常

a). 异常从出发的那一点开始流经pipiLine

b). exceptionCaught默认实现是将异常转发下一个handler处理

c). 如果到达尾部还未处理则被记录为未处理

public class EchoClientHandler extends SimpleChannelInboundHandler<ByteBuf>{
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause){
cause.printStackTrace();
ctx.close();
}
}

4.4.2 出站异常

a). 每个出站操作都返回一个ChannelFuture

public void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise){
promise.addListener(new ChannelFutureListener() {
@Override
public void operationComplete(ChannelFuture future) throws Exception {
if( !future.isSuccess() ){
future.cause().printStackTrace();
future.channel().close();
}
}
})
}

4 - Channelhandler和ChannelPipeline的更多相关文章

  1. 【Netty】ChannelHandler和ChannelPipeline

    一.前言 前面学习了Netty的ByteBuf,接着学习ChannelHandler和ChannelPipeline. 二.ChannelHandler和ChannelPipeline 2.1 Cha ...

  2. Netty实战六之ChannelHandler和ChannelPipeline

    1.Channel的生命周期 Interface Channel定义了一组和ChannelInboundHandler API密切相关的简单但功能强大的状态模型,以下列出Channel的4个状态. C ...

  3. Netty 系列四(ChannelHandler 和 ChannelPipeline).

    一.概念 先来整体的介绍一下这篇博文要介绍的几个概念(Channel.ChannelHandler.ChannelPipeline.ChannelHandlerContext.ChannelPromi ...

  4. netty中的ChannelHandler和ChannelPipeline

    netty中的ChannelHandler和ChannelPipeline ChannelHandler 家族 https://www.w3cschool.cn/essential_netty_in_ ...

  5. Netty的ChannelHandler,ChannelHandlerContext,ChannelPipeline

    本小节一起学习一下ChannelHandler,ChannelHandlerContext,ChannelPipeline这三个Netty常用的组件,不探究它们的底层源码,我们就简单的分析一下用法 首 ...

  6. ChannelHandler,ChannelHandlerContext,ChannelPipeline

    本小节一起学习一下ChannelHandler,ChannelHandlerContext,ChannelPipeline这三个Netty常用的组件,不探究它们的底层源码,我们就简单的分析一下用法 首 ...

  7. Netty学习笔记(番外篇) - ChannelHandler、ChannelPipeline和ChannelHandlerContext的联系

    这一篇是 ChannelHandler 和 ChannelPipeline 的番外篇,主要从源码的角度来学习 ChannelHandler.ChannelHandler 和 ChannelPipeli ...

  8. Netty 框架学习 —— ChannelHandler 与 ChannelPipeline

    ChannelHandler 1. Channel 生命周期 Channel 的生命周期状态如下: 状态 描述 ChannelUnregistered Channel 已经被创建,但还未注册到 Eve ...

  9. Netty学习摘记 —— 再谈ChannelHandler和ChannelPipeline

    本文参考 本篇文章是对<Netty In Action>一书第六章"ChannelHandler和ChannelPipeline",主要内容为ChannelHandle ...

随机推荐

  1. Ajax前端调后台方法

    后台对当前页面类进行注册 Ajax.Utility.RegisterTypeForAjax(typeof(Login));//Login 当前类名 在方法上面加 [Ajax.AjaxMethod(Aj ...

  2. LAMP 1.6 Discuz安装

    1.下载                                                                                                 ...

  3. MySQL绿色版的安装步骤

    由于工作需要最近要开始研究MySQL了(看来学习都是逼出来的),本人对mysql没有研究,可以说一个小白. 下面就从安装开始吧,虽然网上关于这方面的东西很多,还是需要自己把操作过程写下来. 1.数据库 ...

  4. Java探索之旅(14)——文本I/O与读写

    1文件类File    ❶封装文件或路径的属性.不包括创建和读写文件操作.File实例并不会实际创建文件.不论文件存在与否,可以创建任意文件名的实例.两种实例创建方式如下:               ...

  5. 02_android下单元测试

    Java的单元测试JUnit. Java程序入口是main方法.一般不在安卓程序入口 @Override protected void onCreate(Bundle savedInstanceSta ...

  6. Hadoop中Partition的定制

    1.解析Partition Map的结果,会通过partition分发到Reducer上,Reducer做完Reduce操作后,通过OutputFormat,进行输出,下面我们就来分析参与这个过程的类 ...

  7. JSP错误页面

    exception是JSP九大内置对象之一,其实例代表其他页面的异常和错误.只有当页面是错误处理页面时,即isErroePage为 true时,该对象才可以使用.对于C项,errorPage的实质就是 ...

  8. javascript 数组中出现的次数最多的元素

    javascript 数组中出现的次数最多的元素 var arr = [1,-1,2,4,5,5,6,7,5,8,6]; var maxVal = arr[0]; // 数组中的最大值 var min ...

  9. CSS概念 - 可视化格式模型(一) 盒模型与外边距叠加

    可以参考<精通CSS 高级WEB标准解决方案>第三章. 可视化格式模型 可视化格式模型要掌握的3个最重要的CSS概念是 浮动.定位.盒模型. 这些概念控制在页面上安排和显示元素的方式, 形 ...

  10. DES加密解决算法

    /// <summary> /// DES加密算法 /// sKey为8位或16位 /// </summary> /// <param name="pToEnc ...