I/O复用到底是什么意思
UNP网络编程中,有I/O复用的使用,以select和epoll为例,
其中有以下说明:
IO多路复用是指内核一旦发现进程指定的一个或者多个IO条件准备读取,它就通知该进程。IO多路复用适用如下场合:
(1)当客户处理多个描述字时(一般是交互式输入和网络套接口),必须使用I/O复用。
(2)当一个客户同时处理多个套接口时,而这种情况是可能的,但很少出现。
(3)如果一个TCP服务器既要处理监听套接口,又要处理已连接套接口,一般也要用到I/O复用。
(4)如果一个服务器即要处理TCP,又要处理UDP,一般要使用I/O复用。
(5)如果一个服务器要处理多个服务或多个协议,一般要使用I/O复用。
与多进程和多线程技术相比,I/O多路复用技术的最大优势是系统开销小,系统不必创建进程/线程,也不必维护这些进程/线程,从而大大减小了系统的开销。
我的理解:假设现在已经有10000个客户端和服务器通过TCP三次握手,处于已连接状态,也就是有10000个connected_socket,当这10000客户端同时发送数据请求时,服务器通过使用select或者epoll可以同时处理这10000个请求,请问我理解的IO复用对吗?
如果是的话,假设10000个客户端同时发送文件下载的请求,不还是要创建多个进程/线程来处理下载请求吗,否则,一个个的处理,最后一个客户端的文件下载请求要很长时间才能完成啊,怎么就不必创建多个进程/线程