超时是生产环境的底线要求,需分connect和read两阶段独立设置,配合熔断降级、异步分层控制及结构化监控告警。
Python调用外部接口时,不设超时等于裸奔——网络抖动、服务卡顿、对方无响应,都可能让你的程序卡死、线程堆积、资源耗尽。合理设置超时,不是“以防万一”,而是生产环境的底线要求。
requests 库的 timeout 参数实际包含两个阶段:连接超时(connect)和读取超时(read)。只传一个数字(如 timeout=5),等价于 timeout=(5, 5),但两者语义不同、应独立控制:
推荐显式写成元组:requests.get(url, timeout=(3, 10)),可读性高,也方便后续按场景动态调整。
超时只是第一道防线;真正保护系统,得靠熔断+降级+限流组合策略:
用 aiohttp 或 httpx.AsyncClient 时,timeout 不仅作用于单次请求,还需配合 asyncio 的 wait_for 做外层兜底:
timeout=aiohttp.ClientTimeout(total=8, connect=
2, sock_read=6)
asyncio.wait_for(task, timeout=10),防止 DNS 解析卡住、事件循环异常等 client 层无法捕获的挂起total 和 wait_for 时间不能简单叠加,建议外层 timeout 比 client 总超时多 1~2 秒作为缓冲光设了超时没用——你得知道它什么时候被触发、为什么触发:
超时不是性能优化技巧,而是稳定性基建。它不解决根本故障,但能阻止小问题演变成大事故。