0

0

Python select与epoll区别_IO多路复用原理

冷漠man

冷漠man

发布时间:2026-03-06 13:45:13

|

342人浏览过

|

来源于php中文网

原创

python select与epoll区别_io多路复用原理

select 和 epoll 都是 I/O 多路复用机制,但设计目标和适用场景不同

select 是早期 Unix 系统就支持的通用接口,跨平台性好;epoll 是 Linux 2.6+ 特有的高效实现,专为高并发、大量连接优化。两者核心目标一致:让一个线程/进程同时监控多个文件描述符(如 socket)的读写就绪状态,避免为每个连接单独阻塞等待。

select 的工作方式与局限

select 每次调用都需要把整个 fd 集合(通常是 1024 个以内)从用户态拷贝到内核态,并由内核线性遍历所有 fd 判断是否就绪。返回时再把就绪集合拷贝回用户态。这意味着:

  • 时间复杂度是 O(n),n 是监控的 fd 总数,不管其中几个就绪
  • 每次调用前必须重置 fd_set,不能复用上次状态
  • 有默认 FD_SETSIZE 限制(常见为 1024),扩展需重新编译内核或 glibc
  • 无法得知哪个 fd 具体发生了什么事件(如可读 vs 可写),需再次调用 recv/send 试探,可能阻塞

epoll 的核心改进

epoll 把“注册”和“等待”分离,使用三步操作:epoll_create 创建实例,epoll_ctl 添加/修改/删除监听的 fd,epoll_wait 等待就绪事件。关键优势在于:

  • 内核用红黑树管理监听 fd,插入/删除 O(log n);就绪队列用链表,返回就绪 fd 时仅拷贝真正就绪的项,时间复杂度接近 O(1)(就绪数)
  • 无需每次传入全部 fd,也无需反复重置结构体
  • 支持边缘触发(ET)和水平触发(LT)两种模式,ET 可减少重复通知,配合非阻塞 I/O 提升效率
  • 无硬编码 fd 数量上限,只受系统内存和 ulimit 限制

Python 中的实际使用差异

标准库 select.select() 直接封装系统 select;而 select.epoll() 仅在 Linux 上可用,行为更接近原生 epoll。asyncio 在 Linux 默认使用 epoll,在 macOS 用 kqueue,Windows 用 IOCP —— 这正是为了自动适配最优机制。

通义灵码
通义灵码

阿里云出品的一款基于通义大模型的智能编码辅助工具,提供代码智能生成、研发智能问答能力

下载

立即学习Python免费学习笔记(深入)”;

简单示例对比:

# select 方式(伪代码)
read_fds = [sock1, sock2, ...]
while True:
    rlist, _, _ = select.select(read_fds, [], [])
    for s in rlist:
        data = s.recv(1024)  # 可能阻塞,除非设为非阻塞
<h1>epoll 方式(Linux only)</h1><p>ep = select.epoll()
ep.register(sock1, select.EPOLLIN)
ep.register(sock2, select.EPOLLIN)
while True:
events = ep.poll()  # 返回 [(fd, event), ...]
for fd, ev in events:
if ev & select.EPOLLIN:
data = fd.recv(1024)  # 同样建议设为非阻塞

注意:无论 select 还是 epoll,搭配非阻塞 socket 才能真正避免阻塞,这是高效 I/O 的前提。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

449

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

201

2025.07.04

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1825

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

594

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2349

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.19

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1409

2023.07.26

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号