登录
首页 >  Golang >  Go教程

Go HTTP Client 超时:别让默认客户端拖住 goroutine

来源:Golang学习网专题原创

时间:2026-06-08 23:06:00 470浏览 收藏

所属专题:Go 并发治理实战

Go 的 http.DefaultClient 没有总超时。对内部工具脚本影响不大,但在服务端代码里非常危险:下游卡住时,请求 goroutine、连接和内存都会持续占用。

Client.Timeout 是总预算

Client.Timeout 覆盖从发起请求到读取响应体的总时间。它简单直接,适合大多数普通调用,但也要和入口 context 的 deadline 保持一致。

Transport 管连接细节

DialContext、TLSHandshakeTimeout、ResponseHeaderTimeout 和 IdleConnTimeout 分别控制建连、TLS 握手、响应头等待和空闲连接生命周期。它们能帮助你定位到底慢在哪里。

读取响应体也要受控

只设置请求发出前的超时不够,读取 body 同样可能慢。请求结束后必须关闭 body,否则连接无法复用。

代码示例

client := &http.Client{
    Timeout: 800 * time.Millisecond,
    Transport: &http.Transport{
        DialContext: (&net.Dialer{Timeout: 150 * time.Millisecond}).DialContext,
        ResponseHeaderTimeout: 300 * time.Millisecond,
        IdleConnTimeout: 90 * time.Second,
    },
}

上线检查

  • 禁止在服务端使用无超时 DefaultClient。
  • 响应体始终 defer Close。
  • 下游超时指标按目标服务拆分。
声明:本文转载于:Golang学习网专题原创 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>