支撑亿级io的底层基石就是多路复用
什么是多路复用
假设你是一个机场的空管, 你需要管理到你机场的所有的航线, 包括进港,出港, 有些航班需要放到停机坪等待,有些航班需要去登机口接乘客。你会怎么做?
最简单的做法,就是你去招一大批空管员,然后每人盯一架飞机, 从进港,接客,排位,出港,航线监控,直至交接给下一个空港,全程监控。
那么问题就来了:
- 很快你就发现空管塔里面聚集起来一大票的空管员,交通稍微繁忙一点,新的空管员就已经挤不进来了。
- 空管员之间需要协调,屋子里面就1, 2个人的时候还好,几十号人以后 ,基本上就成菜市场了。
- 空管员经常需要更新一些公用的东西,比如起飞显示屏,比如下一个小时后的出港排期,最后你会很惊奇的发现,每个人的时间最后都花在了抢这些资源上。
现实上我们的空管同时管几十架飞机稀松平常的事情。
他们用一个叫flight progress strip的东西 每一个块代表一个航班,不同的槽代表不同的状态,然后一个空管员可以管理一组这样的块(一组航班),而他的工作,就是在航班信息有新的更新的时候,把对应的块放到不同的槽子里面。
回到我们的多路复用,如果你把每一个航线当成一个Sock(I/O 流), 空管当成你的服务端Sock管理代码的话
第一种方法就是最传统的多进程并发模型 (每进来一个新的I/O流会分配一个新的进程管理。)
第二种方法就是I/O多路复用 (单个线程,通过记录跟踪每个I/O流(sock)的状态,来同时管理多个I/O流 。)
多路复用也就是说,在同一个线程里面, 通过拨开关的方式,来同时传输多个I/O流
即一个线程处理多个IO连接
IO多路复用的三种机制Select,Poll,Epoll
多路复用IO也是阻塞IO,只是阻塞的方法是select/poll/epoll。select/epoll的好处就在于单个process就可以同时处理多个网络连接的IO。它的基本原理是select/epoll这个函数会不断轮询所负责的IO操作,当某个IO操作有数据到达时,就通知用户进程。然后由用户进程去操作IO。比较详细的介绍可以参考:
IO多路复用(Select,Poll,Epoll)
最新推荐文章于 2025-01-05 16:25:11 发布
本文以机场空管为比喻,深入浅出地解释了多路复用技术的工作原理及其在处理大量I/O流时的优势。对比了多进程并发模型与I/O多路复用的不同,介绍了Select、Poll和Epoll三种机制。


283

被折叠的 条评论
为什么被折叠?



