您当前的位置: 首页 > 

Netty业务代码执行流程源码解析

发布时间:2020-12-23 21:28:33 ,浏览量:0

worker thread

执行示意图

Handler执行资格:

  • 实现了ChannellnboundHandler
  • 实现方法channelRead不能加注解@Skip
执行流程
  • 多路复用器( Selector )接收到OP_ READ事件
  • 处理 OP_READ事件: NioSocketChannel.NioSocketChannelUnsafe.read
  • 分配一个初始1024字节的byte buffer来接受数据
  • 从 Channet接受数据到byte buffer
  • 记录实际接受数据大小, 调整下次分配byte buffer大小

触发pipeline.fireChannelRead(byteBuf)把读取到的数据传播出去

判断接受 byte buffer是否满载而归:是,尝试继续读取直到没有数据或满16次;否,结束本轮读取,等待下次OP_READ事件

处理业务的本质

数据在pipeline中所有的handler的channelRead()执行过程。

  • Handler要实现io.netty.channel.ChannelnboundHandler#channelRead (ChannelHandlerContext ctx,Object msg),且不能加注解@Skip才能被执行到。
  • 中途可退出,不保证执行到Tail Handler。

默认处理线程就是Channel绑定的NioEventLoop线程,也可以设置其他

pipeline.addLast(new UnorderedThreadPoolEventExecutor(10), serverHandler) 
关注
打赏
1688896170
查看更多评论

暂无认证

  • 0浏览

    0关注

    115984博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文
立即登录/注册

微信扫码登录

0.1185s