首页 > 解决方案 > 如何将 go-retryablehttp 与具有自定义传输的客户端一起使用?

问题描述

我想了解如何将go-retryablehttp与具有自定义传输的客户端一起使用,例如禁用 TLS 验证,如何实现?

标签: go

解决方案


本期所示,您可以访问底层的 http 客户端。这是一个忽略 127.0.0.1:8030 处的自签名证书错误的小示例

package main

import (
    "crypto/tls"

    "github.com/hashicorp/go-retryablehttp"
    "net/http"
)

func main() {
    tr := &http.Transport{
        TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
    }
    retryClient := retryablehttp.NewClient()
    retryClient.HTTPClient.Transport = tr

    req, err := retryablehttp.NewRequest("GET", "https://127.0.0.1:8030", nil)
    if err != nil {
        panic(err)
    }

    _, err = retryClient.Do(req)
    if err != nil {
        panic(err)
    }
}

推荐阅读