您的位置:首页 > 理论基础 > 计算机网络

linux网络编程epoll模型简单总结

2018-02-11 19:34 435 查看
epoll 与 select 和 poll 在使用和实现上有很大区别。首先, epoll 使用一

组函数来完成,而不是单独的一个函数;其次, 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 网络套接字。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息