Netty底层的实现原理和模型结构

本文详细探讨了Netty服务器的底层实现原理,包括其高效的工作流程和独特的模型结构。通过解析Netty如何处理网络I/O,以及其在Java服务器开发中的应用,揭示了Netty在高并发场景下卓越性能的秘密。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Netty框架实际上就是实现了多Reactor多线程模式

mainReactor ———— bossGroup(NioEventLoopGroup) 中的某个NioEventLoop

subReactor ———— workerGroup(NioEventLoopGroup) 中的某个NioEventLoop

acceptor ———— ServerBootstrapAcceptor

ThreadPool ———— 用户自定义线程池

netty的整个工作流程 

(1)、服务器端有两个线程池,(事件循环组),bossGroup负责监听客户端连接,
 wokerGroup负责监听网络读写。

(2)、每个线程池组里面都含有多个NioEventLoop(事件循环线程),
 就是一个死循环,不停的监听。

(3)、每个NioEventLoop(事件循环线程)中有两个对象,
 一个是selector,负责监听绑定在其上的socket的IO事件,
 一个是taskQueue,负责来存放没来得及处理的IO事件。

(4)、bossGroup里面的NioEventLoop监听到了客户端连接事件,做以下三个操作:

	 <1>、轮询accpet事件(客户端连接事件)。
	
	 <2>、监听到了连接请求,就通过accpet(),生成一个nioSocketChannel
	  	 (连接通道),将其注册到workGroup里面的某个NioEventLoop的selector
	
	 <3>、继续处理任务队列。

(5)、workGroup里面的NioEventLoop监听到了连
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

EntyIU

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值