golang中如何实现net.http库超时设置
本文主要介绍"golang中怎么实现net.http库超时设置",希望能够解决您遇到有关问题,下面我们一起来看这篇 "golang中怎么实现net.http库超时设置" 文章。
net.http 包中的超时设置
服务端
app.Server.ReadTimeout
app.Server.WriteTimeout
是针对所有请求设置的选项
默认 net.http keepalived 开启,超时时间为 3 分钟,如下
1942 type tcpKeepAliveListener struct {
1943 *net.TCPListener
1944 }
1945
1946 func (ln tcpKeepAliveListener) Accept() (c net.Conn, err error) {
1947 tc, err := ln.AcceptTCP()
1948 if err != nil {
1949 return
1950 }
1951 tc.SetKeepAlive(true)
1952 tc.SetKeepAlivePeriod(3 * time.Minute)
1953 return tc, nil
1954 }
没看到保活超时的配置选项,生产环境可以禁掉
客户端
刚才看了下,golang http 库客户端有5个超时设置,一个是 Client 里面的 Timeout,一个是 Client 使用的 Transport 的 ResponseHeaderTimeout,还有三个是 Transport 内部的 Dialer 的超时设置,Timeout,KeepAlive,Deadline。
通过查看 golang 代码发现,在执行 http 请求之前, 如果 Client.Timeout > 0,会使用 time.AfterFunc 定义一个回掉函数,超时后调用,此函数会取消正在进行中的请求。
Dialer 的 Timeout 和 Deadline 是连接超时时间,建立连接过程中使用
发送请求,接收响应 分别由两个协程处理。发送请求后,Transport 里的超时时间 ResponseHeaderTimeout 开始计时,因此它指的是等待响应的超时时间。
关于 "golang中怎么实现net.http库超时设置" 就介绍到这。希望大家多多支持编程宝库。
golang怎么用:本文主要介绍"golang如何用",希望能够解决您遇到有关问题,下面我们一起来看这篇 "golang如何用" 文章。1. 利用defer、recover来实现try...catchfunc Try(fun func(), ...