概述
前言:
要对IO模型、多路复用、java NIO网络编程有一定的理解才能看懂。
不同的线程模型,对程序的性能影响很大,要搞钱Netty的线程模型,就要了解一下各种线程模型。
目前存在的线程模型有:
- 传统阻塞I/O服务模型。
- Reactor模型。
首先来说说传统的网络IO线程模型:

特点:
- 采用阻塞IO模式获取输入的数据。
- 每个连接都需要独立的线程完成数据的输入(会造成阻塞)、业务处理、数据返回(会造成阻塞)。也就是一个线程就负责一个客户端连接的所有东西。
问题:
- 当并发量很大时,需要创建大量线程,会耗尽系统资源,就算使用线程池,也会造成大量连接被阻塞。
- 这些线程会被阻塞在read、write操作上面,造成资源浪费。
Reactor模型
Reactor是解决针对传统IO阻塞模式的缺点的解决方法。
Reactor模式就是使用一个线程,然后配合非阻塞IO,IO多路复用模式来代替传统的IO阻塞模式。
Reactor模式对应的叫法有:反应器模式、分发者模式、通知者模式。
根据Reactor数量和处理资源线程池线程数量的不同,可以将Reactor分为三种典型的类型:
- 单Reactor单线程。
- 单Reactor多线程。
- 主从Reactor多线程。
Reactor模型的角色:
- Reactor:用于处理客户端连接的组件,通常一个Reactor

本文围绕Java网络IO线程模型展开,先介绍传统阻塞I/O服务模型的特点与问题,随后重点阐述Reactor模型,包括单Reactor单线程、单Reactor多线程、主从Reactor多线程三种类型,分析各自优缺点及使用场景,最后总结Reactor模型响应快、扩展性和复用性好的优点。
最低0.47元/天 解锁文章
777





