多线程调用epoll_wait()的线程安全问题分析 http://blog.csdn.net/lmh12506/article/details/7836827

来源:互联网 发布:淘宝饰品店推荐 编辑:程序博客网 时间:2024/05/03 20:09
http://blog.csdn.net/lmh12506/article/details/7836827 


多线程调用epoll_wait()的线程安全问题分析

 3041人阅读 评论(1) 收藏 举报
多线程socketthread工作

目录(?)[+]

多线程epoll_wait后得到的活跃fd是线程安全的吗?

或者说多个线程在epoll_wait后,各个线程得到的epoll_event[]里的socket有相同的吗?



有可能各个线程得到的epoll_event[]里的socket有相同的。特别在LT模式下。虽然内核使用了排他锁每次只唤醒一个epoll_wait()进程,但如果在LT模式下,而且唤醒的进程没有处理完该fd的全部数据,那么下一个epoll_wait()进程醒来的时候,就有可能得到该fd还是可读的,这样各个线程得到的epoll_event[]里的socket就有可能是相同的。注意是:可能!!!


加上EPOLLONESHOT ,一个socket就只有一个thread处理,然后再epoll_ctl EPOLL_CTL_MOD修改该fd。


正解,EPOLLONESHOT,
至于ET和LT我还没有进行过对比,但是在大量实践中,LT+EPOLLONESHOT的工作是可靠的。

版权声明:本文为博主原创文章,未经博主允许不得转载。


0 0