解释nginx的epoll的网络I/O模型为什么快的原因
来源:互联网 发布:java gbk编码转utf 8 编辑:程序博客网 时间:2024/06/06 02:41
epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,在开始讨论这个问题之前,先来解释一下为什么需要多路复用IO.
以一个生活中的例子来解释.
假设你在大学中读书,要等待一个朋友来访,而这个朋友只知道你在A号楼,但是不知道你具体住在哪里,于是你们约好了在A号楼门口见面.
如果你使用的阻塞IO模型来处理这个问题,那么你就只能一直守候在A号楼门口等待朋友的到来,在这段时间里你不能做别的事情,不难知道,这种方式的效率是低下的.
现在时代变化了,开始使用多路复用IO模型来处理这个问题.你告诉你的朋友来了A号楼找楼管大妈,让她告诉你该怎么走.这里的楼管大妈扮演的就是多路复用IO的角色.
进一步解释select和epoll模型的差异.
select版大妈做的是如下的事情:比如同学甲的朋友来了,select版大妈比较笨,她带着朋友挨个房间进行查询谁是同学甲,你等的朋友来了,于是在实际的代码中,select版大妈做的是以下的事情:
int n = select(&readset,NULL,NULL,100);for (int i = 0; n > 0; ++i){ if (FD_ISSET(fdarray[i], &readset)) { do_something(fdarray[i]); --n; }}
epoll版大妈就比较先进了,她记下了同学甲的信息,比如说他的房间号,那么等同学甲的朋友到来时,只需要告诉该朋友同学甲在哪个房间即可,不用自己亲自带着人满大楼的找人了.于是epoll版大妈做的事情可以用如下的代码表示:
n=epoll_wait(epfd,events,20,500);for(i=0;i<n;++i){ do_something(events[n]);}
在epoll中,关键的数据结构epoll_event定义如下:
typedef union epoll_data { void *ptr; int fd; __uint32_t u32; __uint64_t u64;} epoll_data_t;struct epoll_event { __uint32_t events; /* Epoll events */ epoll_data_t data; /* User data variable */};
对比最早给出的阻塞IO的处理模型, 可以看到采用了多路复用IO之后, 程序可以自由的进行自己除了IO操作之外的工作, 只有到IO状态发生变化的时候由多路复用IO进行通知, 然后再采取相应的操作, 而不用一直阻塞等待IO状态发生变化了.
从上面的分析也可以看出,epoll比select的提高实际上是一个用空间换时间思想的具体应用.
- 解释nginx的epoll的网络I/O模型为什么快的原因
- I/O模型的有趣解释
- 千百万以上海量连接的select、poll和epoll等网络I/O模型的性能测试与分析提纲
- 网络I/O模型select/poll/epoll
- epoll为什么这么快,epoll的实现原理
- epoll为什么这么快,epoll的实现原理
- epoll为什么这么快,epoll的实现原理
- epoll为什么这么快,epoll的实现原理
- Windows Socket I/O模型 以及 Linux Epoll模型 的有关资料
- Windows Socket I/O模型 以及 Linux Epoll模型 的有关资料
- Windows Socket I/O模型以及Linux Epoll模型的有关资料
- Windows Socket I/O模型 以及 Linux Epoll模型 的有关资料
- 多路复用I/O Epoll的简单使用
- linux的网络模型---epoll
- Linux I/O复用中select poll epoll模型的介绍及其优缺点的比较
- Unix网络编程中的的五种I/O模型
- Unix网络编程中的的五种I/O模型
- 五种常见的网络I/O模型
- [leetcode刷题系列]Jump Game
- Collection:List、Set和Map:HashMap、HashTable区别
- 不错的在线api 网站
- java中静态代码块的用法 static用法详解
- android判断网络连接
- 解释nginx的epoll的网络I/O模型为什么快的原因
- 字符串面试题系列之三:左旋转字符串
- Android之扫描二维码&开启闪光灯
- 《我的第一本c++书》学习笔记:STL中的一些通用算法(一)
- jquery学习(一)
- Micaps3.2二次开发实例教程-6
- 打印Java环境参数
- GNU bash实现机制与源代码简析
- 计划指南