本文迁移并整理自个人之前在博客园的博客。
本文是并发服务器系列学习笔记的第 3 篇。
参考资料:《UNIX网络编程 卷1》
I/O 复用
概念
在之前博文中,我们有简单介绍了 I/O 复用模型的概念,即可以复用同一个线程去完成多个描述符的 I/O 操作
。
I/O 多路复用适用如下场合:
1)当客户处理多个描述符时(一般是交互式输入和网络套接口),必须使用 I/O 复用;
2)当一个客户同时处理多个套接字时,而这种情况是可能的,但很少出现;
3)如果一个 TCP 服务器既要处理监听套接口,又要处理已连接套接口,一般也要用到 I/O 复用;
4)如果一个服务器既要处理 TCP,又要处理 UDP,一般要使用 I/O 复用;
5)如果一个服务器要处理多个服务或多个协议,一般要使用 I/O 复用。
与多进程和多线程技术相比,I/O 多路复用技术的最大优势是系统开销小,系统不必创建进程/线程,也不必维护这些进程/线程,从而大大减小了系统的开销。
more >>