linux网络编程epoll模型简单总结
2018-02-11 19:34
435 查看
epoll 与 select 和 poll 在使用和实现上有很大区别。首先, epoll 使用一
组函数来完成,而不是单独的一个函数;其次, epoll 把用户关心的文件描述
符上的事件放在内核里的一个事件表中,无须向 select 和 poll 那样每次调
用都要重复传入文件描述符集合事件集。
epoll函数的原型为:
功能:创建epoll 监听集合,size: 最大监听数
功能:对描述符对应的事件进行操作
参数说明:
epfd: epoll-ctl 返回的epoll描述符
op:
->EPOLL_CTL_ADD 添加
->EPOLL_CTL_MOD 修改
->EPOLL_CTL_DEL 删除
fd:要添加到到监听集合的描述符
event : 描述符对应的事件
-> EPOLLIN 可读事件
->EPOLLOUT 可写事件
EPOLLET 边缘触发
功能: 开始 epoll 监听,将就绪的事件放到events 事件数组中
参数说明
epfd : epol_creat 返回的epoll 描述符
events:用于存放就绪的事件
maxevents:同时能够处理的就绪事件最大个数,跟events 数组大相同
timeout: opell 超时时间
I/O 多路复用 epoll 模型优缺点:
->思路:单进程(非多线程)调用 epoll_wait()函数来处理多个连接请求。
->优点:单进程(非多线程)可支持同时处理多个网络连接请求,可以达到硬件上限,性能上由于只管理就绪连接,不需要轮询事件集合,因此性能高;
->缺点:仅支持 linux 平台。
epoll模型使用步骤:
1.创建socket
2.定义监听地址信息,并为socket 绑定监听地址
3.开始监听(告诉系统开始监听地址是否有数据到来
4.创建epoll监听集合
5.定义时间结构,并将始建于描述符关联
6,将描述符与事件添加到epoll 监听集合
7,开始epoll 监听(返回值判断)
->. <0 epoll_wait 错误
->=0 : epoll_wait 超时
-> < 0 : 就绪事件个数,将已经就绪的事件放到一个指定的时间数组中,
8.根据就绪的事件个数,循环遍历就绪事件数组
(1)判断事件 fd 是否 等于 监听 描述符,
-> == 处理新连接,将新连接socket 描述符添加到epoll集合监听集合
-> != 其他的数据传输事件
(2)传输若出错,则将描述符从epoll 监听集合中删除,并关闭
9.关闭Socket 网络套接字。
组函数来完成,而不是单独的一个函数;其次, epoll 把用户关心的文件描述
符上的事件放在内核里的一个事件表中,无须向 select 和 poll 那样每次调
用都要重复传入文件描述符集合事件集。
epoll函数的原型为:
int epoll_create(int size);
功能:创建epoll 监听集合,size: 最大监听数
int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);
功能:对描述符对应的事件进行操作
参数说明:
epfd: epoll-ctl 返回的epoll描述符
op:
->EPOLL_CTL_ADD 添加
->EPOLL_CTL_MOD 修改
->EPOLL_CTL_DEL 删除
fd:要添加到到监听集合的描述符
event : 描述符对应的事件
-> EPOLLIN 可读事件
->EPOLLOUT 可写事件
EPOLLET 边缘触发
int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout);
功能: 开始 epoll 监听,将就绪的事件放到events 事件数组中
参数说明
epfd : epol_creat 返回的epoll 描述符
events:用于存放就绪的事件
maxevents:同时能够处理的就绪事件最大个数,跟events 数组大相同
timeout: opell 超时时间
I/O 多路复用 epoll 模型优缺点:
->思路:单进程(非多线程)调用 epoll_wait()函数来处理多个连接请求。
->优点:单进程(非多线程)可支持同时处理多个网络连接请求,可以达到硬件上限,性能上由于只管理就绪连接,不需要轮询事件集合,因此性能高;
->缺点:仅支持 linux 平台。
epoll模型使用步骤:
1.创建socket
2.定义监听地址信息,并为socket 绑定监听地址
3.开始监听(告诉系统开始监听地址是否有数据到来
4.创建epoll监听集合
5.定义时间结构,并将始建于描述符关联
6,将描述符与事件添加到epoll 监听集合
7,开始epoll 监听(返回值判断)
->. <0 epoll_wait 错误
->=0 : epoll_wait 超时
-> < 0 : 就绪事件个数,将已经就绪的事件放到一个指定的时间数组中,
8.根据就绪的事件个数,循环遍历就绪事件数组
(1)判断事件 fd 是否 等于 监听 描述符,
-> == 处理新连接,将新连接socket 描述符添加到epoll集合监听集合
-> != 其他的数据传输事件
(2)传输若出错,则将描述符从epoll 监听集合中删除,并关闭
9.关闭Socket 网络套接字。
相关文章推荐
- ROS探索总结(五)——创建简单的机器人模型smartcar
- ROS探索总结(五)——创建简单的机器人模型smartcar
- 关于linux设备驱动模型,今天做一个简单的理解总结,可能有错误,后面可能会更正
- ADS简单模型参数总结
- ROS探索总结(四)(五)(六)——简单的机器人仿真 创建简单的机器人模型smartcar 使用smartcar进行仿真
- ROS探索总结(五)——创建简单的机器人模型smartcar
- 关于参考古月《ROS探索总结(五)——创建简单的机器人模型smartcar》在kinetic中实现总结
- ROS探索总结(五)——创建简单的机器人模型smartcar
- 推荐算法简单总结
- java Calendar类时间操作简单总结,计算工作日排除法定假日以及周末
- 对 Softirq,tasklet和workqueue做一个简单的总结和分析
- hashcode、equals和==简单总结
- 常用算法总结之排序(五)----简单选择排序
- 对这一年做一个简单总结
- MTK 内存管理简单总结 3
- 我总结的几种简单的调用Com组件的方法
- java 容器的简单总结
- Apache htaccess的简单总结,以及参数的使用
- 2010敏捷大会简单总结及记录
- EPiServer 简单项目总结