当前位置: 首页 > news >正文

【OS】深入理解Linux的五种IO模型

最近逛论坛在知乎看到一篇非常不错的文章,遂收藏,分享给大家
又加深了对io模型的理解

知乎一篇文章:深入理解Linux的五种IO模型

Linux的五种IO模型

阻塞I/O (Blocking I/O)

• 特点:进程在数据准备和拷贝阶段均被挂起,直到操作完成

• 流程:

  1. 调用recvfrom()后线程阻塞
  2. 内核等待数据到达内核缓冲区
  3. 数据从内核空间拷贝到用户空间
  4. 函数返回成功
    • 优点:实现简单,适合低并发场景

• 缺点:每个连接需独立线程/进程,资源消耗大

非阻塞I/O (Non-blocking I/O)

• 特点:立即返回EWOULDBLOCK错误码,需轮询检查状态

• 流程:

  1. 调用recvfrom()立即返回(无数据时返回错误)
  2. 进程持续轮询检查数据状态
  3. 数据就绪后完成拷贝
    • 优点:避免线程阻塞

• 缺点:CPU空转消耗高,实时性差

I/O多路复用 (I/O Multiplexing)

• 核心机制:通过select/poll/epoll监控多个文件描述符

• 工作流程:

  1. 将多个fd注册到监听集合
  2. 调用select()阻塞等待任一fd就绪
  3. 遍历就绪fd进行数据读写
    • 技术对比:

select:位图管理,有1024fd限制

poll:链表实现,无数量限制

epoll:回调机制,性能最优

• 优点:单线程处理多连接,高并发场景首选

信号驱动I/O (Signal-driven I/O)

• 原理:通过SIGIO信号通知数据就绪

• 流程:

  1. 注册信号处理函数(如sigaction
  2. 内核发送SIGIO信号通知数据就绪
  3. 在信号处理函数中调用recvfrom()
    • 优点:避免轮询消耗

• 缺点:信号处理复杂,TCP适用性有限

异步I/O (Asynchronous I/O)

• 核心特征:内核完成全部操作后通知进程

• 流程:

  1. 调用aio_read()立即返回
  2. 内核自主完成数据准备和拷贝
  3. 通过回调或信号通知进程
    • 与同步I/O的本质区别:数据拷贝由内核发起

• 优点:完全非阻塞,性能最高

• 缺点:实现复杂,需内核支持(Linux 2.6+)

关键对比

模型等待阶段是否阻塞拷贝阶段是否阻塞触发方式
阻塞I/O同步
非阻塞I/O否(轮询)同步
I/O多路复用是(select阻塞)同步
信号驱动I/O同步(信号)
异步I/O异步

典型应用场景
• 阻塞I/O:简单客户端工具

• epoll多路复用:Nginx/Redis等高并发服务器

• 异步I/O:大规模存储系统(如数据库)

http://www.xdnf.cn/news/53083.html

相关文章:

  • LED闪烁示例(STC89C52单片机)
  • 1001: 自由落体的计算
  • window.addEventListener 和 document.addEventListener
  • 常用的求职网站
  • 000.初识 dyld
  • nuxt3前端开发以及nuxt3和nuxt2项目的详细差异点
  • INSTEAD OF 详细介绍
  • 致迈协创C1pro考勤系统简介
  • RHCE dns实验
  • 清理C盘组合拳:最高释放空间80GB+
  • Linux 生产者消费者模型
  • C++ vector 之 【模拟实现vector须知、完整的模拟实现 】
  • 【数据结构和算法】1. 数据结构和算法简介、二分搜索
  • 使用NEAT算法探索Gymnasium中的Lunar Lander环境
  • 【AI实践】使用DeepSeek+CherryStudio绘制Mermaid格式图表
  • 深度学习4——深度神经网络训练
  • SpringBoot 基本原理
  • PowerBi如何制作KPI的总览页?
  • Img2img-turbo 在2080Ti上的测试笔记
  • 基于 Elasticsearch 8.12.0 集群创建索引
  • LoRA怎么和Base模型完成输出 ;LoRA完整计算过程; lora前向传播和反向传播 计算过程举例
  • 在 Debian 10.x 安装和配置 Samba
  • 构建具备推理与反思能力的高级 Prompt:LLM 智能代理设计指南
  • 《MySQL:MySQL表的约束-主键/复合主键/唯一键/外键》
  • POSIX标准系统调用详解:从概念到实践
  • Java 实体类链式操作
  • leetcode 1035. Uncrossed Lines
  • Java的IO流 - 字节流和字符流
  • 测试新版oda teigha,开发webcad,实现在线查看dwg图纸
  • 哪个开源协议对用户最友好?开源协议对比