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