原文连接:https://www.zhoubotong.site/post/78.html
开发中对于http请求是经常遇到,一般可能网络延迟或接口返回超时,对于发起客户端的请求,
除了设置超时时间外,请求重试是很有必要考虑的,我们不用重复造轮子,可以使用 https://github.com/rafaeljesus/retry-go 第三方库,
retry-go的使用非常简单,如下是一个发起 HTTP Get 请求的重试示例 :- package main
- import (
- "io/ioutil"
- "log"
- "net/http"
- "time"
- "github.com/rafaeljesus/retry-go"
- )
- var (
- attempts = 3 //最大重试次数
- sleepTime = time.Second * 2 //重试延迟时间
- )
- func main() {
- _, err := retry.DoHTTP(func() (*http.Response, error) {
- return makeRequest()
- }, attempts, sleepTime)
- if err != nil {
- log.Print("retry.DoHTTP Failed")
- return
- }
- log.Print("retry.DoHTTP OK")
- }
- // 发送http请求
- func makeRequest() (*http.Response, error) {
- client := http.Client{
- Timeout: 2 * time.Second, // 设置请求超时时间
- }
- req, err := client.Get("https://www.baidu2.com") // 模拟不存在的url请求
- if err != nil {
- log.Printf(err.Error())
- return nil, err
- }
- body, err := ioutil.ReadAll(req.Body)
- if err != nil {
- log.Printf(err.Error())
- return nil, err
- }
- log.Printf("响应数据 %v\\n", string(body))
- defer req.Body.Close()
- res := &http.Response{}
- return res, nil
- }
复制代码 运行结果:

我们看到尝试执行了指定的3次请求次数。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |