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(), ...