Netty学习之旅------源码分析ChannelPipeline实现原理,为什么大公司一定要使用微服务

本文详细分析了Netty的ChannelPipeline的实现原理,从ServerBootstrap的init方法到Channel的注册过程,揭示了Netty事件处理的链式结构。同时,探讨了大公司采用微服务的原因,强调了ChannelPipeline在处理链条中的拦截机制。通过ChannelPipeline的fireChannelRegistered等方法,展示了事件沿调用链传播的过程,并解释了如何区分输入和输出事件的Handler。最后,文章结合服务器视角阐述了Netty事件流的方向和Handler编排顺序。
摘要由CSDN通过智能技术生成

1.2.1.1 ServerBootstrap init方法

1.2.1.2 group().register 方法

根据Netty线程模型,group()返回的是EventLoopGroup,然后Netty会从该EventLoopGroup中获取下一个EventLoop来执行。由于程序入口使用的是NioServerSocketChannel,故本例最终会使用NioEventLoop来作为事件处理器来服务,这里的register方法,其实现在NioEventLoop的父类SingleThreadEventLoop中。

有关Channel的IO类操作,最终都会转发给Unsafe类去执行,直接进入到AbstractUnsafe中

register方法,确保绑定操作在通道所关联的事件处理器(Eve

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值