使用Go http重試請求的示例

開發中對於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次請求次數。

到此這篇關於使用Go http重試請求的文章就介紹到這瞭,更多相關go http請求內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: