epoll⾼性能最根本的原因是,epoll 可以同时监听多个fd事件,这在很⼤程度地减少了⽆⽤的进程上下⽂切换,让进程更专注地处理⽹络请求。
其实在内核的硬、软中断上下⽂中,包从⽹卡接收过来进⾏处理,然后放到socket的接
收队列。再找到socket关联的epiter,并把它添加到epol对象的就绪链表中。
在⽤户进程中,通过调⽤epoll wait来 查看就绪链表中是否有事件到达,如果有,直
接取⾛进⾏处理。处理完毕再次调⽤epoll_ wait。 在⾼并发的实践中,只要活⼉⾜够多,
epoll walt根本不会让进程阻塞。⽤户进程会⼀直⼲活⼉,⼀直⼲活⼉,直到epoll watt⾥
实在没活⼉可⼲的时候才主动让出CPU。这就是epoll⾼效的核⼼原因所在!