golang http 连接超时和传输超时的例子

时间:2021-05-23

golang 测试代码

package mainimport ( "net/http" "net/url" "fmt" "io/ioutil" "time" "net" "crypto/tls")func TimeoutDialer(cTimeout time.Duration, rwTimeout time.Duration) func(net, addr string) (c net.Conn, err error) { return func(netw, addr string) (net.Conn, error) { conn, err := net.DialTimeout(netw, addr, cTimeout) if err != nil { return nil, err } conn.SetDeadline(time.Now().Add(rwTimeout)) return conn, nil }}func main() { connectTimeout := 5 * time.Second readWriteTimeout := 100 * time.Millisecond c := http.Client{ Transport: &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, Dial: TimeoutDialer(connectTimeout, readWriteTimeout), }, } uri := "https://" req, err := http.NewRequest(http.MethodPost, uri, nil) if err != nil { fmt.Println("req error:" + err.Error()) return } req.Header = http.Header{} req.Header["Connection"] = []string{"Close"} req.Header["User-Agent"] = []string{"wpt-http-client/1.1"} data := make(url.Values) data["name"] = []string{"baixs"} data["hobby"] = []string{"runing"} resp, err := c.Do(req) if err != nil { fmt.Println("do error,err:" + err.Error()) return } respBody, err := ioutil.ReadAll(resp.Body) fmt.Println(string(respBody))}

测试结果

连接超时(包括握手)

传输超时(也就是读写,从accept开始计算 )

以上这篇golang http 连接超时和传输超时的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章