对于epoll_wait/poll/select等函数一般设置了一个超时时间。如果超时时间为0,那么在没有任何网络I/O时间和其他任务处理的情况下,这些线程实际上会空转,白白地浪费了CPU时间片。
如果设置的超时时间大于0,在没有网络I/O事件的情况,epool_wait/poll/select等函数仍然需要挂起指定时间才能返回,导致其他的任务不能被及时的执行,影响其他任务不能被及时的处理,也就是说其他任务一旦产生,其处理起来具有一定的延时性。这样是不好的,该如何处理这些情况呢?
其实这样是最好的,如果没有网络IO事件和其他任务要处理,那么这些工作线程最好直接挂起而不是空转;如果有其他任务要处理,这些工作线程要立刻能处理这些任务而不是在epoll_wait/poll/selec挂起指定时间后才开始处理这些任务。这个可以通过唤醒fd解决。当我们需要处理其他任务的时候,像唤醒fd输入一个字节,这个fd就立马可读的了,epoll_wait/poll/select就会被唤醒,返回,这样就可以做接下来所做的事情了。
实现唤醒fd的3种方式:
1.管道pipe
2.int eventfd(unsigned int initval, int flags);
3.int socketpair(int domain, int type, int protocol, int sv[2]);