Netty架构
文章目录
前置知识:Reactor模型
Doug Lea在 “Scalable IO in Java” 中给了很好的阐述。NIO中Reactor的核心是Selector
。Reactor 模式的典型实现:
单Reactor+单线程模型
这种单线程模型不能充分利用多核资源,所以实际使用的不多。
单Reactor+多线程模型
Tomcat使用的这种模型
主从Reactor+多线程模型
Netty的Reactor模型
Netty的简介
优势
- 使用NioEventLoop(聚合一个Selector)线程组负载均衡的处理请求。一个NioEventLoop聚合了一个多路复用器Selector,因此可以处理成百上千的客户端连接,Netty的处理策略是每当有一个新的客户端接入,则从NioEventLoop线程组中顺序获取一个可用的NioEventLoop,当到达数组上限之后,重新返回到0,通过这种方式,可以基本保证各个NioEventLoop的负载均衡。一个客户端连接只注册到一个NioEventLoop上,这样就避免了多个IO线程去并发操作它。
- Netty通过串行化设计理念降低了用户的开发难度,提升了处理性能。利用线程组实现了多个串行化线程水平并行执行,线程之间并没有交集,这样既可以充分利用多核提升并行处理能力,同时避免了线程上下文的切换和并发保护带来的额外性能损耗。