Python中HTTP连接复用需复用requests.Session()对象,按(scheme,host,port)分组管理urllib3连接池,配置pool_maxsize和retries可优化性能,避免因服务端关闭、空闲超时等导致复用失效。

Python 中的 HTTP 连接复用(Connection Reuse)是提升网络请求性能的关键机制,核心在于避免重复建立 TCP 连接和 TLS 握手。默认情况下,requests 库(基于 urllib3)会自动复用连接,但需满足特定条件,否则仍可能频繁新建连接,拖慢批量请求速度。
连接复用的前提:Keep-Alive 与相同会话
HTTP/1.1 默认启用 Connection: keep-alive,但服务端可主动关闭;客户端必须复用同一 Session 实例,且目标域名、端口、TLS 配置一致。若每次调用都新建 requests.get(),即使 URL 相同,底层也会创建新连接池,无法复用。
- ✅ 正确做法:复用
requests.Session()对象发起多个请求 - ❌ 错误做法:连续写多次
requests.get("https://api.example.com/1") - ⚠️ 注意:不同子域(如
api.example.com和www.example.com)视为不同连接池,不共享连接
urllib3 连接池:控制复用粒度
requests 底层使用 urllib3 管理连接池。每个 Session 维护一个 PoolManager,按 (scheme, host, port) 分组管理独立的 HTTPConnectionPool。可通过配置精细调控:
- maxsize:单个池最大空闲连接数(默认 10),超过时旧连接被关闭
- block=True:当连接达上限时阻塞等待空闲连接(而非抛错)
- retries:对临时失败(如超时)自动重试,避免因偶发失败新建连接
示例:session = requests.Session(); adapter = requests.adapters.HTTPAdapter(pool_maxsize=20, max_retries=3); session.mount("https://", adapter)
立即学习“Python免费学习笔记(深入)”;
PHP5学习对象教程由美国人古曼兹、贝肯、瑞桑斯编著,简张桂翻译,电子工业出版社于2007年12月1日出版的关于PHP5应用程序的技术类图书。该书全面介绍了PHP 5中的新功能、编程方法及设计模式,还分析阐述了PHP 5中新的数据库连接处理、错误处理和XML处理等机制,帮助读者系统了解、熟练掌握和高效应用PHP。
长连接失效场景与应对
连接复用不是永久有效的。以下情况会导致连接被关闭或失效:
- 服务端返回
Connection: close响应头 - TCP 连接空闲超时(服务端通常设为 60s,
urllib3默认检测并清理过期连接) - SSL/TLS 会话过期或证书变更(尤其在负载均衡后端轮换时)
- 客户端显式调用
session.close()或进程退出
建议在高并发短周期任务中,复用 Session 并设置合理 pool_maxsize;长期运行服务可配合健康检查或定期重建 Session 避免陈旧连接堆积。
验证是否真正复用了连接
可通过日志或底层属性确认:
- 启用
urllib3调试日志:import logging; logging.basicConfig(level=logging.DEBUG),观察是否出现"Starting new HTTPS connection"(新建)或"Resetting dropped connection"(复用失败) - 检查连接池状态:
session.adapters["https://"].poolmanager.pools.size()查看当前活跃池数量 - 抓包观察 TCP 连接数:用
tcpdump或 Wireshark 对比复用前后 SYN 包数量
不复杂但容易忽略。










