合理配置http.Transport是实现Go语言HTTP连接复用的关键,需全局复用Transport、调整MaxIdleConns和IdleConnTimeout等参数,并结合context超时控制与指标监控,确保高并发下连接高效复用。
Go 语言原生的 http.Client 默认就支持连接复用(Keep-Alive),但要真正发挥性能,不能只靠默认配置——关键在于合理控制连接生命周期、复用粒度和资源边界。
每次新建 http.Client 并不会带来额外复用能力;真正管理连接的是其内部的 http.Transport。多个请求共用同一个 Transport 实例,才能共享底层连接池。
http.Client(或至少复用它的 Transport),避免为每个请求/协程创建新 client默认的 Transport 对高并发短连接场景不够友好,需根据实际负载调整:
1000,视 QPS 调整)连接复用不等于放任请求无限等待。超时和取消必须由上层控制,否则空闲连接可能被阻塞线程占住,导致池子“假死”:
client.Do(req) 都应传入带 timeout 或 cancel 的 context.Context
time.Sleep 模拟重试,改用 context.WithTimeout + 指数退避别只看代码——用指标验证:
http.DefaultClient.Transport 或自定义 transport 的 IdleConnStats()(需 Go 1.19+)response.Header.Get("Connection"),复用成功时通常为 keep-alive
netstat -an | grep :443 | grep ESTABLISHED | wc -l 对比调优前后连接数变化GODEBUG=http2debug=2 查看 HTTP/2 复用细节(如流复用、SETTINGS 帧)基本上就这些。连接复用不是“开了就行”的开关,而是 Transport 配置、请求上下文、服务端响应行为三者协同的结果。不复杂但容易忽略。