[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]netty的多个handler的顺序问题

上一篇:[备忘]spring事务里的connection
下一篇:[备忘]postgresql的jdbc参数

添加日期:2021/2/2 15:08:16 快速返回   返回列表 阅读810次
ch.pipeline().addLast(new EchoOutboundHandler1());
ch.pipeline().addLast(new EchoOutboundHandler2());

ch.pipeline().addLast(new EchoInboundHandler1());
ch.pipeline().addLast(new EchoInboundHandler2());
----------------------------------------
链表中的顺序为head->out1->out2->in1->in2->tail
如果是in2里执行的write,则会从tail往前找Outbound执行,所以会执行out2、out1

建议的顺序:
先写outHandler,再写inHandler。
in的按顺序执行,out的逆序执行。
----------------------------------------
netty 将数据写入 socket 的过程分析
https://blog.conn4575.com/p/java/netty/how-does-netty-write-to-socket/

inbound 事件从 headContext 开始,依次调用中间 handler 的对应方法,逐渐向尾部“冒泡”,最终所有事件都会到达TailContext ,TailContext 什么都做,将所有到达的事件都吞掉即可。outbound 事件从tailContext 开始(如果是某个中间 handler 发起的,就从这个 handler 对应的 context 开始),向链表头部传递,各个 handler 做出相应处理后最终传递给 HeadContext
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved