Linux的五种IO模型: 阻塞、非阻塞、IO多路复用、事件驱动、异步
ps:IO多路复用和非阻塞是并列的关系,不过一般来说IO多路复用都是和非阻塞搭配使用的。
阻塞模型: 一次网络IO时,C端发出请求,S端收到。当C端发出一个请求,进行IO时,就不能进行其他操作了,需要同步的等待结果的返回。

IO多路复用模型: 有多个C端同时发送请求,这些IO操作会被selector(epoll,kqueue)给暂时挂起,入内存队列。此时S端可以自己选择什么时候来读取并处理这些IO,也就是说S端可以同时hold住多个IO。
S端通过sel.select()每次选出一个sock,然后对这个sock上的事件进行处理。所以IO多路复用,在没有用其他异步API的情况下,还是同步的操作。

参考:
IO多路复用
本文深入解析Linux系统的五种IO模型:阻塞、非阻塞、IO多路复用、事件驱动及异步IO。详细阐述了每种模型的工作原理,特别强调了IO多路复用在提高服务器效率方面的作用。
1069

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



