golang中http连接超时和传输超时的示例分析
这篇文章主要介绍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开始计算 )
以上是“golang中http连接超时和传输超时的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!
文章标题:golang中http连接超时和传输超时的示例分析
转载来源:http://pcwzsj.com/article/pijiso.html