图解IO多路复用模型之select、poll、epoll

简介: 图解IO多路复用模型之select、poll、epoll

在之前的文章《如何不使用任何模型裸建服务器》(详情见上篇文章)中,我们最终使用了多线程来解决多客户端连接问题。Linux下,一般默认为一个线程占有8M的线程栈空间,那么如果有1024*8个连接,就需要8G的线程栈空间,显然具有高额的资源开销。那么IO多路复用模型,就是为了用单线程来实现多客户端连接的技术

Select模型

该模型的图解大致如下:

对应的核心代码如下:

Select模型存在以下缺点:

  1. 默认情况下,fdset只有1024个bit位,也就是说只能1024个连接。
  2. 每次select函数调用后,都需要检测所有文件描述符。
  3. 每次select函数调用时,内核都需要进行拷贝文件描述符集合。
  4. 参描较多,较难理解。

Poll模型

Poll模型与select模型的运行规则基本一致。

该模型的图解大致如下:

对应的核心代码如下:

Poll模型相比select模型,有以下优点:

  1. 将文件描述符交给结构体数组进行记录和管理,可连接数量可自定义,并且大大增加。
  2. 参数相对更简单易懂。

epoll模型

epoll是典型的用于高效地处理大量并发连接的模型

该模型的图解大致如下:

Epoll核心代码:

epoll模型相比select、poll模型,有以下优点:

  1. 支持边缘触发。当recv函数一次性无法读取全部数据的时候,可以在下次循环中继续读取数据,有效地避免粘包等问题。
  2. 使用红黑树管理文件描述符和对应事件。在连接数巨大的时候,epoll的红黑树数据结构可以快速地实现节点的增删改查。包括相应事件发生的时候,内核也能迅速地查找到相应的节点并且进行后续操作。
  3. 直接从内核获取就绪状态的文件描述符。用户无需遍历全部地文件描述符,挨个检测它们是什么状态。
  4. 数据结构直接建立在内核中,无需将存储文件描述符集合和监听事件的数据结构实例反复复制进入内核中。
  5. 没有连接数量大小的限制。
目录
相关文章
|
10月前
|
Java Linux API
IO模型
BIO、NIO、AIO是Java中处理网络I/O的三种模型。BIO为阻塞式,每个连接需单独线程,高并发下性能受限;NIO通过非阻塞与多路复用提升并发能力,少量线程可处理大量请求;AIO进一步实现异步非阻塞,数据复制时线程可释放,由回调机制处理后续操作。三者适用于不同场景,BIO易用但低效,NIO高效但复杂,AIO理论性能更优但目前在Linux上仍依赖多路复用实现。Java 21引入虚拟线程后,BIO也可兼具高性能与易编写特性。
298 2
|
存储 Linux C语言
Linux C/C++之IO多路复用(aio)
这篇文章介绍了Linux中IO多路复用技术epoll和异步IO技术aio的区别、执行过程、编程模型以及具体的编程实现方式。
854 1
Linux C/C++之IO多路复用(aio)
|
监控 应用服务中间件 Linux
掌握并发模型:深度揭露网络IO复用并发模型的原理。
总结,网络 I/O 复用并发模型通过实现非阻塞 I/O、引入 I/O 复用技术如 select、poll 和 epoll,以及采用 Reactor 模式等技巧,为多任务并发提供了有效的解决方案。这样的模型有效提高了系统资源利用率,以及保证了并发任务的高效执行。在现实中,这种模型在许多网络应用程序和分布式系统中都取得了很好的应用成果。
329 35
|
网络协议 前端开发 Java
网络协议与IO模型
网络协议与IO模型
598 4
网络协议与IO模型
|
开发者
什么是面向网络的IO模型?
【10月更文挑战第6天】什么是面向网络的IO模型?
182 3
|
数据挖掘 开发者
网络IO模型
【10月更文挑战第6天】网络IO模型
604 3
|
数据挖掘 开发者
网络IO模型如何选择?
网络IO模型如何选择?【10月更文挑战第5天】
228 2
|
数据库
同步IO模型是一种常见的编程模型
【10月更文挑战第5天】同步IO模型是一种常见的编程模型
217 2
|
缓存 Java Linux
硬核图解网络IO模型!
硬核图解网络IO模型!
330 1
|
Linux C++
Linux C/C++之IO多路复用(poll,epoll)
这篇文章详细介绍了Linux下C/C++编程中IO多路复用的两种机制:poll和epoll,包括它们的比较、编程模型、函数原型以及如何使用这些机制实现服务器端和客户端之间的多个连接。
757 0
Linux C/C++之IO多路复用(poll,epoll)