您的位置:首页 > 运维架构 > Nginx

Nginx学习笔记一_UNIX中的IO模型

2015-09-13 13:24 344 查看
要理解NGINX框架,首先必须了解网络编程中的5种基本IO模型。

(1)阻塞式IO:进程会阻塞于IO系统调用,直到数据准备好,系统调用完成返回。

(2)非阻塞式IO:进程不会阻塞与系统调用。当检测到数据未准备好时,不是将进程阻塞,而是立即返回一个错误。

(3)IO复用:该模型也会阻塞,但它与阻塞式IO的区别是,阻塞的系统调用不同。什么意思呢?我们知道阻塞式IO都   是阻塞在read/write一类的IO的系统调用,而IO复用是阻塞在select/poll这一类系统调用。这两类系统调用的区别是: read/write只能监听单个系统描述符(即只能监听一个IO的数据是否准备好),而select/poll可同时监听多个系统描述符。

(4)信号驱动式IO:该驱动方式靠的是SIGIO信号和信号处理函数,当数据准备好,内核会为进程产生一个SIGIO信号,让信号处理函数处理,可以将IO系统调用放在信号处理函数里,也可以放在进程主循环里。

(5)异步IO(POSIX规范定义):不导致请求进程阻塞的IO。上面四种都是会导致进程阻塞的IO,称为同步IO。为何?阻塞式IO会阻塞于等待数据和IO操作这两个过程。非阻塞式IO不会阻塞于等待数据过程,但会阻塞于IO操作过程。IO复用是阻塞于等待数据和IO操作两个过程。信号驱动式IO阻塞于IO操作过程。因此这四种IO模型都会导致进程阻塞,属于同步IO。而异步IO指的是等待数据和IO操作都不会阻塞进程,系统调用是立即返回的,而且会在IO操作完成时为该进程产生一个通知的信号。这算是一种理想的异步IO模型

我们可以看出异步IO才是真正意义上的非阻塞。

参考书籍:

《UNIX网络编程》卷一 套接字联网API  人民邮电出版社
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  nginx unix