为什么Python异步程序在Windows上连接数受限_通过ProactorEventLoop解决
时间:2026-05-03 17:06:41 460浏览 收藏
今天golang学习网给大家带来了《为什么Python异步程序在Windows上连接数受限_通过ProactorEventLoop解决》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~
根本原因是Windows默认SelectorEventLoop调用受限于512句柄的select()系统调用;应改用支持IOCP的ProactorEventLoop,并同步调优连接池等配套组件。

Windows上asyncio报“too many file descriptors in select()”的根本原因
这不是Python代码写错了,是底层事件循环选错了。默认的 SelectorEventLoop 在 Windows 上直接调用 select() 系统调用,而 Windows 的 select() 实现硬性限制为 512 个文件描述符——包括 socket、临时文件、管道等所有打开的句柄。一旦并发连接(比如 aiohttp 发起的 1000 个请求)触发这个上限,立刻抛出 ValueError: too many file descriptors in select()。
如何强制使用ProactorEventLoop(Windows专属解法)
Windows 有更现代的异步 I/O 机制:IOCP(I/O Completion Port)。ProactorEventLoop 就是专为此设计的,它不依赖 select(),理论上支持数万级并发连接。
- 最稳妥的方式:在程序入口显式设置策略(推荐放在脚本最开头)
import asyncio asyncio.set_event_loop_policy(asyncio.WindowsProactorEventLoopPolicy())
- 如果已创建过 loop(比如某些框架提前初始化),需先关闭再重建:
asyncio.set_event_loop_policy(asyncio.WindowsProactorEventLoopPolicy()) loop = asyncio.new_event_loop() asyncio.set_event_loop(loop)
- 命令行临时启用(调试用):
python -c "import asyncio; asyncio.set_event_loop_policy(asyncio.WindowsProactorEventLoopPolicy()); print('OK')"
ProactorEventLoop的兼容性注意点
它不是万能银弹,有些旧库或特定操作在 Proactor 下行为不同:
asyncio.subprocess在 Proactor 下必须用asyncio.create_subprocess_exec,不能用loop.run_in_executor包裹subprocess.Popen,否则会卡死- 部分第三方库(如老版本
uvloop)不支持 Proactor,强行使用会报RuntimeError: ProactorEventLoop is not supported - 如果你用的是 Python ≤ 3.7,
ProactorEventLoop对 SSL/TLS 支持较弱,建议升到 3.8+ - 它不支持
loop.add_reader/add_writer这类低层 API,这些是 Selector 特有的
别只换 EventLoop,连接池也要同步调优
换完 ProactorEventLoop 后,如果还卡在几百并发,大概率是上层连接池没跟上。比如 aiohttp.TCPConnector 默认 limit=100,这比 512 还小——它成了新瓶颈。
- 把
limit提到 300–500(视目标服务器承受力而定),但别盲目拉满 - 务必设
limit_per_host=20,防止单域名被限流或封IP - 加
enable_cleanup_closed=True,避免异常断连后句柄残留 - 数据库池(如
asyncpg.create_pool)的max_size也要按实际 DB 能力配,不是越大越好
真正卡住你的,往往不是事件循环本身,而是它和连接池、DNS 缓存、TCP Keepalive 这些组件之间的配合细节——这些地方不调,光换 loop 只是把 512 的墙拆了,又撞上另一堵 200 的墙。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
283 收藏
-
282 收藏
-
257 收藏
-
133 收藏
-
222 收藏
-
445 收藏
-
222 收藏
-
266 收藏
-
419 收藏
-
152 收藏
-
283 收藏
-
370 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习