同步异步阻塞非阻塞

同步和异步 阻塞和非阻塞

阻塞非阻塞是调用后是否立即返回。

同步异步是针对两个对象,"请求发起者"和"请求处理者"。发起请求后怎么获得结果,是自己反复询问,还是等别人主动通知。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

内核等待网卡的数据,内核将网卡的数据写入内核缓冲区。

内核将从内核缓冲区中将网卡的数据拷贝到用户空间。

用户进行read,内核等待网卡的数据,然后将数据拷贝到用户空间,如果用户线程一直在等待,等待时"挂起",不做任何事情。这就是阻塞。

用户在read后会立即返回结果,然后不断轮询,直到数据拷贝到用户空间。这就是非阻塞。

在内核将数据拷贝到用户空间时,用户线程在等待拷贝完成,就是同步。

在内核将数据拷贝到用户空间时,用户线程不等待,拷贝完成后,内核通知用户已经拷贝完成。这就是异步。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

调用read,然后等待内核将数据拷贝到用户空间,期间用户一直等待,不做其他事情,就是同步阻塞。

调用read,然后立即返回一个结果,不管内核是否已经完成数据的拷贝,如果没有完成就返回一个错误,然后不断地询问,每次询问都会立即返回,直到拷贝完成,返回正确结果,就是同步非阻塞。

调用read,然后去做其他的事情,直到内核完成了数据拷贝,通知用户去处理数据。就是异步非阻塞。

异步一定是非阻塞,同步可能是阻塞也可能是非阻塞。

去食堂吃饭,分为两步,第一步厨师炒完菜,第二步服务员将菜算过来。

我点好菜后,等待厨师炒完菜,再等待服务员送过来,期间什么都不做。这就是同步阻塞。

我点好菜后,就去做其他的事情,然后每隔一段时间问一下,我的菜好了吗,直到服务员端上来。这就是同步非阻塞。

我点好菜后,就去做其他的事情,服务员把菜端上来后,通知我菜好了。这就是异步非阻塞。

一次完整的网络读操作,分为两步,第一步内核等待数据,第二步内核将数据拷贝到用户空间。

epoll其实是同步IO

复制代码
用户:调用epoll_wait → 阻塞等待【步骤1完成】
内核:步骤1完成(数据到内核缓冲区)
内核:唤醒epoll_wait,返回"可读"
用户:调用recv → 进入内核,执行【步骤2】(拷贝数据)
用户:等待recv返回(拷贝完成)
用户:拿到数据

用户等待了步骤1(在epoll_wait里) 也 等待了步骤2(在recv里)。 所以是同步。

io_uring 才是异步

复制代码
用户:调用io_uring_enter,提交读请求 → 立即返回(不等待)
内核:【步骤1 + 步骤2】全权负责
     - 等待数据到达
     - 自动拷贝数据到用户指定的内存
内核:全部完成后,在完成队列里放一个完成事件
用户:稍后调用io_uring_enter(或轮询)检查完成事件
用户:发现完成事件,直接使用数据(无需再调用recv)

用户没有等待步骤1,也没有等待步骤2。全由内核干完。所以是异步。

相关推荐
乘云数字DATABUFF2 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--4 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森4 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜5 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB6 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
zzzzzz3107 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode7 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220708 天前
如何搭建本地yum源(上)
运维
大树8811 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠11 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql