news 2026/5/21 11:04:10

【Linux】五种IO模型与非阻塞IO

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Linux】五种IO模型与非阻塞IO

Linux 五种 IO 模型 + 非阻塞 IO 的完整梳理
(2025-2026 面试/实战最常考版本)

Linux 下最经典的五种 IO 模型,几乎是所有中高级后端/网络编程面试必问内容。

序号IO 模型名称阻塞阶段进程在内核等待数据时是否阻塞?进程在数据从内核→用户缓冲区时是否阻塞?是否同步 IO?实际使用代表技术性能排序(延迟)
1阻塞式 IO(Blocking IO)等待数据到达 + 拷贝到用户缓冲区几乎所有最原始的 read/write★(最慢)
2非阻塞式 IO(Non-blocking IO)—(轮询)否(立即返回)是(数据到了才拷贝)设置 O_NONBLOCK + 循环 read★★
3IO 多路复用(IO Multiplexing)等待任意一个 fd 可读/可写是(在 select/poll/epoll 上阻塞)否(内核只通知,拷贝仍由进程发起)select / poll / epoll / kqueue★★★★
4信号驱动式 IO(Signal-driven IO)—(内核数据到达时发信号)是(收到信号后自己去 read,仍会阻塞拷贝)sigaction + SIGIO★★★(很少用)
5异步 IO(Asynchronous IO)整个过程都不阻塞否(内核完成拷贝后通知)aio_read / libaio / io_uring★★★★★(最强)

重点对比图(建议背诵的思维导图版)

是否在等待内核数据时阻塞? 是否在数据从内核→用户缓冲区时阻塞? 阻塞IO 是 是 非阻塞IO 否(轮询) 是 IO多路复用 是(阻塞在select/epoll_wait) 否 信号驱动IO 否(等信号) 是 异步IO 否 否

非阻塞 IO(Non-blocking IO)的真实使用状态(非常重要!)

// 最经典的错误写法(很多人这样写然后骂系统垃圾)while(1){intn=read(fd,buf,sizeof(buf));if(n>0)// 读到数据process(buf,n);elseif(n==0)// 连接关闭break;else{// n == -1if(errno==EAGAIN||errno==EWOULDBLOCK);// 没数据,继续轮询elseerror();}}

上面这种写法的问题

  1. CPU 占用极高(疯狂轮询)
  2. 延迟不确定(取决于你轮询的频率)
  3. 不适合大量连接(几千个 fd 就爆炸)

非阻塞 IO 的正确打开方式(2024-2026 主流做法)

非阻塞 IO 几乎从来不单独使用!!! 真正的高性能方案永远是下面这几种组合: 1. 非阻塞 + 忙轮询 → 极低延迟场景(游戏、HFT),几百个连接还能接受 2. 非阻塞 + sleep(小间隔) → 低质量方案(基本淘汰) 3. 非阻塞 + select/poll → 古老方案(几百~一千连接) 4. 非阻塞 + epoll(ET/LT) → 目前最主流方案(单线程轻松10w+连接) 5. 非阻塞 + io_uring → 2023~2026 年最强趋势(零拷贝+内核态调度)

五种模型实际项目中使用频率(2025-2026 真实分布)

占比模型典型场景代表框架/库
7080%IO多路复用(epoll)绝大部分高并发网络服务器nginx, redis, netty, libevent, libuv
1020%异步 IO(io_uring)高性能存储、网络代理、新一代服务器redis 7+, nginx with io_uring, SPDK
~5%纯阻塞 IO简单脚本、命令行工具、低并发业务大量业务代码
~2%非阻塞 + 轮询极致低延迟场景(游戏服务器、HFT)自研轮询服务器
极少信号驱动 IO几乎已被淘汰(实现复杂,收益低)基本没人用

快速记忆口诀(面试可直接说)

问你用什么模型的时候,直接甩这句话: "我们项目主要用 epoll 的 ET 模式 + 非阻塞 IO, 少量高性能存储场景正在迁移到 io_uring 异步 IO。 传统阻塞 IO 只在一些低并发工具类代码中使用。"

总结一句话

在现代高并发网络编程里,单纯的「非阻塞 IO」几乎没有生存空间,真正起作用的是「非阻塞 IO + 多路复用」或「非阻塞 IO + 异步 IO(io_uring)」。

需要我针对某个具体模型(比如 epoll ET/LT 区别、io_uring 入门实战、信号驱动的正确用法等)再展开详细讲解吗?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/7 2:25:07

MySQL知识汇总:讲一讲MySQL中Select语句的执行顺序

MySQL 中 SELECT 语句的逻辑执行顺序 (非常重要且经常被问到的高频知识点) MySQL 的 SELECT 语句书写顺序和实际执行顺序是完全不同的,这是很多人在理解 SQL 执行过程时最容易混淆的地方。 书写顺序(我们平时怎么写的&#xff0…

作者头像 李华
网站建设 2026/5/15 4:05:47

手把手教你9款AI神器1天生成25000字论文

还在为论文的Deadline焦头烂额吗?从选题、查文献、搭建框架到反复修改、降重、格式调整,写论文仿佛是一场没有尽头的马拉松。今天,作为一名资深“论文斗士”,我将为你彻底改变这一局面。我将手把手教你,如何巧妙地组合…

作者头像 李华
网站建设 2026/5/19 15:28:01

基于Spring Boot的疗养院管理系统的设计与实现(11711)

有需要的同学,源代码和配套文档领取,加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码(前后端源代码SQL脚本)配套文档(LWPPT开题报告)远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/5/6 17:41:23

基于MATLAB的单闭环直流调速系统设计(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于MATLAB的单闭环直流调速系统设计(设计源文件万字报告讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码 本设计包括设计报告,仿真程序,电气接线图。 设计要求 (1)该调速系统能进行平滑的速度调节&a…

作者头像 李华
网站建设 2026/5/4 17:41:02

PMP知识--十大知识域(下)

六 项目资源管理规划资源管理&估算活动资源规划资源管理估算活动资源获取资源&建设团队获取资源建设团队塔克曼阶梯理论(重点)建设团队的工具与技术管理团队&控制资源管理团队冲突管理情商控制资源七 项目沟通管理概述&规划沟通管理概述…

作者头像 李华
网站建设 2026/5/1 7:50:31

基于Spring Boot的酒店管理系统_n4w99n6v-java毕业设计

目录摘要关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!摘要 该系统基于Spring Boot框架开发,旨在为酒店行业提供高效、智能化的管理解决方案。采用B/S架构&#xff0c…

作者头像 李华