IO多路复用模型之select,poll,epoll

IO多路复用模型有三种模式:select,poll,epoll

select:通过进程监控文件描述符(fd)的方式

  1. 每次selelct把fd从用户空间copy到kernel
  2. 然后遍历fd判断文件是否就绪
  3. 单个进程操作fd数量默认限制1024

poll:poll使用链表保存文件描述符。没有fd数量限制。

epoll:epoll提供了三个函数,epoll_create,epoll_ctl和epoll_wait,epoll_create是创建一个epoll句柄;epoll_ctl是注册要监听的事件类型;epoll_wait则是等待事件的产生。

  1. epoll_create()系统调用。此调用返回一个句柄,之后所有的使用都依靠这个句柄来标识。、
  2. epoll_ctl()系统调用。通过此调用向epoll对象中添加、删除、修改感兴趣的事件,返回0标识成功,返回-1表示失败。
  3. epoll_wait()系统调用。通过此调用收集收集在epoll监控中已经发生的事件。
上一篇:kafka重复消费问题


下一篇:Kafka常见的导致重复消费原因和解决方案