golang http 连接超时和传输超时

golang 测试代码

package main

import (
    "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://www.youtobe.com"
    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开始计算 )

这里写图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值