IO 模型:
在Linux下主要有四种I/O模型:
1、阻塞IO
套接字建立以后所处的模式就是阻塞IO模式,它是最简单、最常用,但是效率最低的模式。
阻塞读操作:read recv ; recvfrom
写操作:write send
其他操作:accept connect
2、非阻塞IO、
可以防止进程阻塞在IO操作上需要轮询,它是不普遍使用的一种模式,当应用程序使用非阻塞模式的套接字时,它需要使用一个循环不停的测试套接字是否可读(称为polling):应用程序不停的polling 内核来检查IO操作是否就绪,这是一个极其浪费 CPU 资源的操作。
3、信号驱动IO
一种异步通讯模型
信号驱动式IO是进程预先告知内核,使得某个文件描述符发生事件时候,内核使用信号通知相关进程。
对于TCP来说信号驱动IO几乎无用
因为该信号SIGIO产生的过于频繁,不能区分具体是哪种事件
例如套接字上某个连接请求已经完成、某个断开连接请求已经发起、某个连接关闭、数据已经到达套接字、数据已经从套接字发送走(发送缓冲区有空闲啦)、发生异步错误等等。
4、IO多路复用
IO多路复用是指:内核一旦发现进程指定的一个或多个IO产生事件,他就通知改进程
为什么要用多路复用
应用程序如果同时处理多路输入输出流,如果采用阻塞模式,将得不到预期的目的
如果采用非阻塞模式,对多个输入进行轮询,但是由太浪费时间
如果设置多个进程,分别处理一条数据通路,将产生同步互斥问题,让程序变得复杂。
与多进程多线程相比,IO多路复用技术的最大优势是系统开销小
系统不必创建进程/线程,也不必维护这些进程线程,从而大大减少系统开销。