netty权威指南 - EventLoop事件循环

本文探讨了Netty如何通过EventLoop事件循环实现高性能网络编程。相较于传统线程模型,Netty利用Java NIO避免了线程阻塞,一个线程能处理多个IO请求。Netty的EventLoop包含单线程执行事件和事件队列,减少了线程切换开销,但同时也强调避免阻塞IO线程以保证效率。
摘要由CSDN通过智能技术生成

netty作为一个高性能网络框架,基于java线程实现了自己的线程模型,即EventLoop事件循环。

传统线程模型

在传统的java网络编程中,IO逻辑是同步阻塞的。也就是说,每次创建一个socket连接,就会有一个线程与该socket绑定,该线程不会去处理其他socket。如果有100个请求同时到来,会使用100个线程来处理。如果有200个请求同时到来,但是线程池中只有100个线程,那就只会同时处理100个请求,剩下100个请求阻塞在队列中。

在实际的编程开发中,有两个原则:

  • IO性能比计算性能低。按照传统模式进行网络编程,一个线程在其生命周期内,真正运行时间的比例是很低的,大部分时间处于阻塞状态以等待IO完成。
  • 不同线程之间的上下文切换也是需要耗费性能。一旦线程数提高,成百上千的线程光是线程切换就会耗费大量时间,而这些线程中绝大部分都处于IO阻塞状态,真正工作的很少。

NIO

基于以上两点,java在1.4搞出来了NIO(非阻塞IO)模型。NIO的具体说明不在本文章的范围内,只需要明白一点:NIO不会像传统IO一样阻塞线程。一个线程可以处理多个IO请求,同时线程不会因为IO而进入阻塞状态,提高执行效率。

netty中的线程模型

netty是在java NIO的基础上,封装的一套异步非阻塞的网络框架。所以netty继承了NIO的特点:单线程处理多个IO的事件。基于NIO逻辑,netty封装了java的线程,形成了一套自己的线程模型:事件循环模型EventLoop。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值