IO多路复用的理解

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

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

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

相关推荐
峰顶听歌的鲸鱼37 分钟前
Kubernetes管理
运维·笔记·云原生·容器·kubernetes·云计算
霖霖总总1 小时前
[小技巧42]InnoDB 索引与 MVCC 的协同工作原理
运维·数据库·mysql
CRMEB系统商城1 小时前
CRMEB多商户系统(PHP)- 移动端二开之基本容器组件使用
运维·开发语言·小程序·php
小镇学者1 小时前
【python】python项目是如何部署到服务器上的
服务器·python·github
HIT_Weston1 小时前
103、【Ubuntu】【Hugo】搭建私人博客:搜索功能(四)
linux·运维·ubuntu
2501_945837431 小时前
事件驱动无服务器,Knative重塑原子化运算
服务器
yaoxin5211231 小时前
296. Java Stream API - 二元操作符与“单位元“
java·服务器·windows
视觉震撼3 小时前
逐步指南:为大模型构建自动化知识图谱
运维·自动化·知识图谱
yeflx3 小时前
OpenMVS源码编译
运维
有泽改之_4 小时前
ssh命令使用
linux·运维·ssh