Python之select、poll、epoll模型的区别

发布时间:2022-04-18 09:55:35 人气:158 作者:多测师

  select、poll、epoll 模型的区别?(属于多路复用IO的模型)

  都是i/o多路复用的机制,监视多个socket是否发生变化,本质上都是同步i/o

  select,poll实现需要自己不断轮询所有监测对象,直到对象发生变化,在这个阶段中,可能要睡眠和唤醒多次交替,而epoll也需要调用epoll_wait不断轮询就绪链表,但是当对象发生变化时,会调用回调函数,将变化的对象放入就绪链接表中,并唤醒在epoll_wait中进入睡眠的进程。虽然都会睡眠和唤醒,但是select和poll在被唤醒的时候要遍历整个监测对象集合,而epoll只要判断就绪链表是否为空即可,节省了大量cpu的时间

  select、poll、epoll都是IO多路复用的机制,但select,poll,epoll本质上都是同步I/O,

  因为他们都需要在读写事件就绪后自己负责进行读写,也就是说这个读写过程是阻塞的.

Python之select、poll、epoll模型的区别

  FD(文件描述符)

  select模型

  优点:

  1:可移植性好,在某些Unix系统不支持poll()

  2:对于超时值提供了更好的精度:微妙,而poll是毫秒

  缺点:

  1:最大并发数限制,因为一个进程所打开的 FD (文件描述符)是有限制的,由 FD_SETSIZE 设置,默认值是 1024/2048 ,因此 Select 模型的最大并发数就被相应限制了。

  2:效率问题,select每次调用都会线性扫描全部的FD集合,所以将FD_SETSIZE 改大,会越慢

  3:需要维护一个用来存放大量fd的数据结构,这样会使得用户空间和内核空间在传递该结构时复制开销大。

  poll本质上和select 没有区别,它将用户传入的数组拷贝到内核空间,

  它没有最大连接数的限制,原因是它基于链表来存储的但是同样有一个缺点:

  大量的fd的数组被整体复制于用户态和内核地址空间,而不管这样的复制是不是有意义

  以上内容为大家介绍了Python之select、poll、epoll模型的区别,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注多测师。https://www.e70w.com/xwzx/


返回列表
在线客服
联系方式

热线电话

17727591462

上班时间

周一到周五

二维码
线