IO多路复用的理解

  • IO:网络IO
  • 多路:多个链接
  • 复用:复用一个或多个线程
  • 在IO多路复用中,当一个线程在等待IO操作时,实际上是将该线程中的事件循环或IO轮询操作交给了操作系统内核 。这样的操作系统调用通常会将线程置于休眠状态,直到至少一个监视的IO事件就绪。此时,不会占用CPU资源,而是允许CPU去处理其他任务。

  • 当有一个或多个IO事件就绪时,操作系统会通知等待的线程 ,线程从休眠状态中唤醒,并处理就绪的IO事件。这种机制允许单个线程处理多个IO连接,提高了系统的效率和性能。因此,IO多路复用是一种高效的并发编程技术,特别适用于高并发的网络服务器应用,如Web服务器和数据库服务器等。

  • 总结:IO多路复用实现了线程的复用,而不是CPU内核的复用。这也是IO多路复用的一个主要优势之一:在一个线程中同时监视多个IO事件,而不需要为每个IO连接创建一个独立的线程。这样可以大大减少线程的创建和销毁开销,从而节省系统资源并提高并发处理能力。

相关推荐
莫问前路漫漫10 小时前
Electerm 连接远程服务器完整指南
运维·服务器·git
苏宸啊10 小时前
Linux下diy程序:进度条
linux·运维·服务器
70asunflower10 小时前
Python with 语句与上下文管理完全教程
linux·服务器·python
tritone10 小时前
学习Chef自动化配置管理工具,为了实践环境部署,我选择了**阿贝云**的**免费虚拟主机**和**免费云服务器**来搭建测试平台。
服务器·学习·自动化
j_xxx404_10 小时前
Linux:调试器-gdb/cgdb使用
linux·运维·服务器
艳阳天_.10 小时前
华为云欧拉服务器问题记录
运维·服务器·华为云
驱动探索者10 小时前
AMD EPYC 服务器 CPU 学习
运维·服务器·学习·cpu
市安10 小时前
docker命令知识点1
运维·docker·云原生·容器·eureka
SmartRadio11 小时前
ESP32-S3实现KVM远控+云玩功能 完整方案
运维·python·计算机外设·esp32·kvm·云玩
重生之绝世牛码11 小时前
Linux软件安装 —— PostgreSQL集群安装(主从复制集群)
大数据·linux·运维·数据库·postgresql·软件安装·postgresql主从集群