ToB企服应用市场:ToB评测及商务社交产业平台

标题: 使用Go http重试请求 [打印本页]

作者: 火影    时间: 2022-9-16 17:24
标题: 使用Go http重试请求
原文连接:https://www.zhoubotong.site/post/78.html
开发中对于http请求是经常遇到,一般可能网络延迟或接口返回超时,对于发起客户端的请求,
除了设置超时时间外,请求重试是很有必要考虑的,我们不用重复造轮子,可以使用 https://github.com/rafaeljesus/retry-go 第三方库,
retry-go的使用非常简单,如下是一个发起 HTTP Get 请求的重试示例 :
  1. package main
  2. import (
  3.     "io/ioutil"
  4.     "log"
  5.     "net/http"
  6.     "time"
  7.     "github.com/rafaeljesus/retry-go"
  8. )
  9. var (
  10.     attempts  = 3               //最大重试次数
  11.     sleepTime = time.Second * 2 //重试延迟时间
  12. )
  13. func main() {
  14.     _, err := retry.DoHTTP(func() (*http.Response, error) {
  15.     return makeRequest()
  16.     }, attempts, sleepTime)
  17.     if err != nil {
  18.         log.Print("retry.DoHTTP Failed")
  19.     return
  20.     }
  21.     log.Print("retry.DoHTTP OK")
  22. }
  23. // 发送http请求
  24. func makeRequest() (*http.Response, error) {
  25.     client := http.Client{
  26.     Timeout: 2 * time.Second, // 设置请求超时时间
  27.     }
  28.     req, err := client.Get("https://www.baidu2.com") // 模拟不存在的url请求
  29.     if err != nil {
  30.         log.Printf(err.Error())
  31.         return nil, err
  32.     }
  33.     body, err := ioutil.ReadAll(req.Body)
  34.     if err != nil {
  35.         log.Printf(err.Error())
  36.         return nil, err
  37.     }
  38.     log.Printf("响应数据 %v\\n", string(body))
  39.     defer req.Body.Close()
  40.     res := &http.Response{}
  41.     return res, nil
  42. }
复制代码
运行结果:

我们看到尝试执行了指定的3次请求次数。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4