EPOLL使用注意事项:
1、没有监控事件变化,切记不要使用epoll_ctl 中 MOD方式修改,即使设置相同的监控事件,会产生多余的事件;
2、使用READ 和WRITE的进行数据的接收和发送,对于SOCKET 是NOBLOCK方式的情况下,一定读写到错误出现,然后进行错误判断,并检测对端CLOSE SOCKET的情况;
3、网络异常中断的情况,SOCKET READ, WRITE的异常处理是判断不出来的,只用通过上层的应用协议进行判断,同时增加SOCKET 超时的判断,通过设置超时时间,结合应用协议,将长时间无数据传输的SOCKET进行CLOSE处理,释放SOCKET的资源,另外可以在应用协议中增加心跳数据协议;
4、注意ET,LT使用的区别,以及和SOCKET的 NOBLOCK和BLOCK的配合使用,网上的例子有很多;
5、使用EPOLL进行SOCKET 线程池设计,SOCKET的 CONNECT和状态监测放在一个任务中,通过状态监视将后续处理分配到对应的线程池中的某一任务上,将READ和WRITE的操作放到另外的线程任务中,可以通过队列的方式进行分配,也可以通过反消息的方式来进行,一个是主动,一个是被动。队列方式取的方式有竞争,消息推的方式无竞争但费资源。