原文连接: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
}

运行结果:
使用Go http重试请求
我们看到尝试执行了指定的3次请求次数。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。