使用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!