http://blog.csdn.net/lmh12506/article/details/7836827
多线程调用epoll_wait()的线程安全问题分析
2012-08-06 20:57 3041人阅读 评论(1) 收藏 举报
多线程 socket thread 工作
目录(?)[+]
多线程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的工作是可靠的。
至于ET和LT我还没有进行过对比,但是在大量实践中,LT+EPOLLONESHOT的工作是可靠的。
版权声明:本文为博主原创文章,未经博主允许不得转载。