epoll监听文件_深入理解 Epoll

Epoll是Linux 2.6内核为了处理高并发场景而设计的系统调用,其时间复杂度为O(1),优于线性复杂度的模型。关键函数包括epoll_create、epoll_ctl和epoll_wait。Epoll有两种触发模式:边沿触发和水平触发,前者仅触发一次,后者会一直触发。Epoll利用红黑树存储文件描述符,减少用户态和内核态的拷贝,提高效率。在大量文件描述符监听时,Epoll的IO性能不会下降,且通过mmap加速信息传递。
摘要由CSDN通过智能技术生成

95d717319503240013e4ede2ba8d8a8c.png

Epoll

epoll - I/O event notification facility

介绍

通常来说,实现处理tcp请求,为一个连接一个线程,在高并发的场景,这种多线程模型与Epoll相比就显得相形见绌了。epoll是linux2.6内核的一个新的系统调用,epoll在设计之初,就是为了替代select, poll线性复杂度的模型,epoll的时间复杂度为O(1), 也就意味着,epoll在高并发场景,随着文件描述符的增长,有良好的可扩展性。

  • selectpoll 监听文件描述符list,进行一个线性的查找 O(n)
  • epoll: 使用了内核文件级别的回调机制O(1)
下图展示了文件描述符的量级和CPU耗时

a3ac0d135b072407d293bacca4fa735b.png

/proc/sys/fs/epoll/max_user_watches

表示用户能注册到epoll实例中的最大文件描述符的数量限制。

f0d160a7908d67a38a724a44a3b2746a.png

关键函数

  • epoll_create1: 创建一个epoll实例,文件描述符
  • epoll_ctl: 将监听的文件描述符添加到epoll实例中,实例代码为将标准输入文件描述符添加到epoll中
  • epoll_wait: 等待epoll事件从epoll实例中发生, 并返回事件以及对应文件描述符l

epoll 关键的核心数据结构如下:

typedef union epoll_data
{
    
  void *ptr;
  int fd;
  uint32_t u32;
  uint64_t u64;
} epoll_data_t;

struct epoll_event
{
    
  uint32_t events;  /* Epoll events */
  epoll_data_t data;    /* User data variable */
};

边沿触发vs水平触发

epoll事件有两种模型,边沿触发:edge-triggered (ET), 水平触发:level-triggered (LT)

水平触发(level-triggered)

  • socket接收缓冲区不为空 有数据可读
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值