原文連接:https://www.zhoubotong.site/post/78.html
開發(fā)中對(duì)于http請(qǐng)求是經(jīng)常遇到,一般可能網(wǎng)絡(luò)延遲或接口返回超時(shí),對(duì)于發(fā)起客戶端的請(qǐng)求,目前創(chuàng)新互聯(lián)已為上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、棗陽網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
除了設(shè)置超時(shí)時(shí)間外,請(qǐng)求重試是很有必要考慮的,我們不用重復(fù)造輪子,可以使用https://github.com/rafaeljesus/retry-go第三方庫,
retry-go的使用非常簡(jiǎn)單,如下是一個(gè)發(fā)起 HTTP Get 請(qǐng)求的重試示例 :
package main
import (
"io/ioutil"
"log"
"net/http"
"time"
"github.com/rafaeljesus/retry-go"
)
var (
attempts = 3 //最大重試次數(shù)
sleepTime = time.Second * 2 //重試延遲時(shí)間
)
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")
}
// 發(fā)送http請(qǐng)求
func makeRequest() (*http.Response, error) {
client := http.Client{
Timeout: 2 * time.Second, // 設(shè)置請(qǐng)求超時(shí)時(shí)間
}
req, err := client.Get("https://www.baidu2.com") // 模擬不存在的url請(qǐng)求
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("響應(yīng)數(shù)據(jù) %v\\n", string(body))
defer req.Body.Close()
res := &http.Response{}
return res, nil
}
運(yùn)行結(jié)果:
我們看到嘗試執(zhí)行了指定的3次請(qǐng)求次數(shù)。