epoll中EPOLLSHOT的使用

EPOLLSHOT的作用主要用于多线程中

epoll在某次循环中唤醒一个事件,并用某个工作进程去处理该fd,此后如果不注册EPOLLSHOT,在该fd时间如果工作线程处理的不及时,主线程仍会唤醒这个时间,并另派线程池中另一个线程也来处理这个fd。

为了避免这种情况,需要在注册时间时加上EPOLLSHOT标志,EPOLLSHOT相当于说,某次循环中epoll_wait唤醒该事件fd后,就会从注册中删除该fd,也就是说以后不会epollfd的表格中将不会再有这个fd,也就不会出现多个线程同时处理一个fd的情况。

对于主线程,主线程的职责在于:

a).主线程负责epoll循环

b).当当前唤醒的事件fd为监听套接字时,由主线程来转换套接字,在转换套接字的过程中,主线程的epoll循环是处于停顿的,因为listenfd的工作线程实际上就是主线程,因此对于listenfd不需要注册EPOLLONESHOT,因为在listenfd上工作时主线程的epoll处于停顿,不会出现多个线程同时处理listenfd的情况。同时,在将监听套接字转换为套接字connfd后,将connfd注册进入epoll,此时需要附加上EPOLLONESHOT标志,因为对connfd的处理是由工作线程来处理的,要保证同时只有一个线程在处理某个fd。

3).当当前唤醒的时间fd为非监听套接字时,将该fd的处理push进去生产者消费者模型的队列中,待工作线程处理。

对于工作线程:

a).当前工作线程工作未完成,如在EPOLLIN中读出数据后。对于整个工作流程来说,读出数据只是工作的一半,还需要将处理后的数据写到对端,但由于注册了EPOLLONESHOT,EPOLLIN的事件被唤醒后该fd已经从epollfd中删去,所以对于尚未完成的工作,要重新注册,比如这里,重新注册fd为EPOLL|EPOLLET|EPOLLONESHOT。EPOLLONESHOT是必须的,因为要保证向对端写入时只有一个线程在该fd上工作。

b).当前工作线程已经完成,此时该fd已经无意义,因此将该fd从epollfd中remove掉。

转载于:https://www.cnblogs.com/lxy-xf/p/11307100.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
epoll_wait是一个系统调用,用于等待epoll文件描述符上的I/O事件。它的函数原型如下: ```c #include <sys/epoll.h> int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout); ``` 其,epfd是epoll的文件描述符,events是用于存储就绪事件的数组,maxevents是events数组的大小,timeout是等待的超时时间。 使用epoll_wait的过程如下: 1. 创建epoll实例:使用epoll_create函数创建一个epoll实例,返回一个epoll的文件描述符。 2. 注册监控事件:使用epoll_ctl函数将需要监控的文件描述符添加到epoll实例,并指定需要监控的事件类型。 3. 等待就绪事件:使用epoll_wait函数等待就绪事件的发生。当有事件发生时,epoll_wait会将就绪事件的信息填充到events数组,并返回就绪事件的数量。 4. 处理就绪事件:根据返回的就绪事件数量,遍历events数组,处理每个就绪事件。 在使用epoll_wait时,可以选择使用LT(水平触发)或ET(边沿触发)模式。LT模式下,当文件描述符上有事件发生时,epoll_wait会立即返回;而ET模式下,只有当文件描述符上的事件状态发生变化时,epoll_wait才会返回。 参考资料提供了更详细的使用案例和常见面试问题,可以进一步了解epoll_wait的使用。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [epoll_wait详解](https://blog.csdn.net/zhoumuyu_yu/article/details/112476477)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v12^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Linux下的I/O复用技术 — epoll如何使用epoll_create、epoll_ctl、epoll_wait) 以及 LT/ET 使用过程解析](https://blog.csdn.net/JMW1407/article/details/107963618)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v12^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值