```
// Get 提交
func Get(api string, params, headers map[string]string, tryTimes int) (error, int, interface{}) {
// 创建请求
req, _ := http.NewRequest("GET", api, nil)
// GET 请求携带查询参数
q := req.URL.Query()
if len(params) > 0 {
for key, value := range params {
q.Add(key, value)
}
}
req.URL.RawQuery = q.Encode()
// 设置请求头
if len(headers) > 0 {
for key, value := range headers {
req.Header.Set(key, value)
}
}
// 发送请求
resp, err := client.Do(req)
if err != nil {
if tryTimes > 0 {
return Get(api, params, headers, tryTimes-1)
}
// 上报日志
return err, 0, nil
}
// 关闭连接
defer resp.Body.Close()
// 读取内容
body, err := io.ReadAll(resp.Body)
if err != nil {
// 上报日志
return err, resp.StatusCode, nil
}
return nil, resp.StatusCode, string(body)
}
```
有谁知道这是什么原因吗?并发请求总是隔段时间就提示:golang Client.Timeout exceeded while awaiting headers
DreamingPHPer · · 2950 次点击这样重试的话,tcp 的四元组是不是一样的呀。那前一个请求如果超过了客户端的的最大等待时间,报错再次发起请求,还是同一个tcp 链接,服务端那边还是没有处理完的。
#6
更多评论