我在客户端进行了一次往返,并设置了一次重试一次。问题是,有时我的客户端触发“上下文取消”,整个处理似乎以300 my结束,但我没有设置超时。怎么触发的?
func RoundTrip(req *http.Request)(res *http.Response, err error){
for i:=0; i<1; i++ {
transport = http.DefaultTransport
res, err = transport.RoundTrip(req)
if err == nil {
break;
}
}
return
}发布于 2022-08-01 13:21:29
可以使用Request.WithContext方法或NewRequestWithContext函数将上下文添加到请求中。取消上下文时,它应该传播到处理请求的所有函数。
更新
抱歉,我以为你想取消请求,而不是问为什么。无论如何,给出你对这个答案的评论:
但是在300 in中取消了上下文
300毫秒很短。如果时间更长,我建议调整net.DefaultTransport中的计时器;但是,我猜想底层的TCP连接被拒绝/限制,导致RoundTrip失败。TCP限制可以是内部的(DNS查找错误等)或服务器端的限制。您需要对问题进行更多的分析才能进行调试。
https://stackoverflow.com/questions/73194023
复制相似问题