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

        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 网络套接字。

你可能感兴趣的:(Linux)