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库超时设置”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。