115、asyncio 异步编程(一):事件循环、协程对象、await 关键字深入
上周五晚上十一点,我正盯着监控面板上一条诡异的日志发呆——一个爬虫服务在高峰期突然卡死,所有请求排队等待,CPU 占用却只有 5%。重启后恢复正常,但第二天同一时间又复现。排查了数据库连接池、线程锁、内存泄漏,最后用 strace 跟踪系统调用才发现:某个第三方 API 的 HTTP 请求用了同步库 requests,在协程里阻塞了事件循环。那一刻我意识到,很多人(包括曾经的我)对 asyncio 的理解还停留在“会用 async/await 写个 demo”的层面。
事件循环:那个看不见的调度器
事件循环是 asyncio 的心脏,但很多人把它想得太玄乎。简单说,它就是一个死循环,不断从任务队列里取出协程对象执行,遇到 await 就挂起当前任务,切到下一个。Python 3.7 之后,asyncio.run() 帮你创建和关闭事件循环,但底层原理必须吃透。
看这段代码,我当年踩过的坑:
import asyncio
async def worker
订阅专栏 解锁全文
:事件循环、协程对象、await 关键字深入&spm=1001.2101.3001.5002&articleId=162516157&d=1&t=3&u=548fa65f609a424b9cd9541224dc42f5)
349

被折叠的 条评论
为什么被折叠?



