深入浅出RPC---5、网络IO模型
linux-dash
A beautiful web dashboard for Linux
项目地址:https://gitcode.com/gh_mirrors/li/linux-dash
免费下载资源
·
网络IO模型
有哪些网络IO模型
主要包含以下几种:
- 同步阻塞 IO(BIO)
- 同步非阻塞 IO(NIO)
- IO 多路复用
- 信号驱动IO
- 异步非阻塞 IO(AIO)
常用的是同步阻塞 IO 和 IO 多路复用模型。
什么是阻塞IO模型
IO多路复用
IO多路复用的实现主要有select,poll和epoll模式。
文件描述符:
在Linux系统中一切皆可以看成是文件,文件又可分为:普通文件、目录文件、链接文件和设备文件。 三者的区别:
select | poll epoll | |
---|---|---|
操作方式 | 遍历 | 遍历 |
底层实现 | bitmap | 数组 |
IO效率 | 每次调用都进行线性 遍历,时间复杂度为 O(n) | 遍历,时间复杂度为 O(n) 每次调用都进行线性 遍历,时间复杂度为 O(n) |
最大连接数 | 1024(x86)或 2048(x64) | 无上限 |
fd拷贝 | 每次调用select,都 需要把fd集合从用户 态拷贝到内核态 | 每次调用poll,都需 要把fd集合从用户态 拷贝到内核态 |
基于select的 I/O 复用模型:
在基于select的 I/O 复用模型中,会用到 Select,这个函数也会使进程阻塞,但是和阻塞 I/O 所不同的是这两 个函数可以同时对多个 I/O 操作。而且可以同时对多个读操作,多个写操作的 I/O 函数进行检测,直到有数据 可读或可写时,才真正调用 I/O 操作函数。
select/poll处理流程:
epoll的处理流程:
epoll 可以说是I/O 多路复用最新的一个实现,epoll 修复了poll 和select绝大部分问题, 比如:
epoll 是线程安全的。 epoll 不仅告诉你sock组里面的数据,还会告诉你具体哪个sock连接有数据,不用进程 独自轮询查找。
为什么阻塞 IO 和 IO 多路复用最为常用?
在实际的网络 IO 的应用中,需要的是系统内核的支持以及编程语言的支持。现在大多数系统内核都会支持阻 塞 IO、非阻塞 IO 和 IO 多路复用,但像信号驱动 IO、异步 IO,只有高版本的 Linux 系统内核才会支持。
RPC 框架应该采用哪种网络 IO 模型?
- IO 多路复用应用特点:
IO 多路复用更适合高并发的场景,可以用较少的进程(线程)处理较多的 socket 的 IO 请求,但使用难度比较高。 - 阻塞 IO应用特点:
与 IO 多路复用相比,阻塞 IO 每处理一个 socket 的 IO 请求都会阻塞进程(线程),但使用难度较低。 - RPC框架应用:
RPC 调用在大多数的情况下,是一个高并发调用的场景, 在 RPC 框架的实现中,一般会选择 IO 多路复用的方式。
GitHub 加速计划 / li / linux-dash
6
1
下载
A beautiful web dashboard for Linux
最近提交(Master分支:3 个月前 )
186a802e
added ecosystem file for PM2 4 年前
5def40a3
Add host customization support for the NodeJS version 4 年前
更多推荐
已为社区贡献1条内容
所有评论(0)