Netty核心源码剖析(二)

本文深入剖析了Netty在接受请求的过程,从EventLoop的逻辑开始,详细讲解了如何通过NioServerSocketChannel的accept()方法获取SocketChannel,并封装为NioSocketChannel,接着添加到容器中,然后在pipeline中执行handler的ChannelRead()方法,最终在ServerBootstrapAcceptor中设置NioSocketChannel的handler并注册到workerGroup。
摘要由CSDN通过智能技术生成

1.Netty接受请求过程源码剖析

1>.从之前的Netty启动过程源码剖析中,我们得知服务器最终注册了一个Accept事件等待客户端的连接.我们也知道,NioServerSocketChannel将自己注册到了bossGroup单例线程池(reactor线程)上,也就是EventLoop;

2>.先简单说下EventLoop的逻辑,EventLoop 的作用是一个死循环,而这个循环中做3件事情:

①.有条件的等待Nio事件;

②.处理Nio事件;

③.处理消息队列中的任务;

3>.仍用前面的项目来分析: 入到NioEventLoop源码中后,在private void processSelectedKey(SelectionKey k, AbstractNioChannel ch)方法开始调试,最终我们要分析到AbstractNioChannel的doBeginRead()方法,当到这个方法时,针对于这个客户端的连接就完成了,接下来就可以监听读事件了;


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值