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。