在进行超时时间设置之前我们需要了解一次http请求经历的过程
- 浏览器进行DNS域名解析,得到对应的IP地址
- 根据这个IP,找到对应的服务器建立连接(三次握手)
- 建立TCP连接后发起HTTP请求(一个完整的http请求报文)
- 服务器响应HTTP请求,返回数据(服务器如何响应)
- 客户端对页面进行渲染呈现给用户
- 服务器关闭TCP连接(四次挥手)
在客户端和服务器之间通常有一层网关来负责路由和负载均衡:


DNS和TCP的超时时间通常由系统指定,DNS默认为5s,TCP建了超时默认为127s
所以下面从客户端、网关、服务端三个方面来讲解下HTTP请求的超时时间设置:
以JS为例
(1)使用
其中timeout指整个请求过程的超时时间。

以nginx为例:
在nginx.conf配置文件中可以指定超时时间
其中:
- 连接超时(Connection Timeout): 这是指客户端尝试与服务器建立连接时的最大等待时间。如果在这个时间内没有建立连接(例如,服务器没有响应或者网络延迟很高),客户端就会放弃尝试并抛出一个超时异常。
- 读超时(Read Timeout): 读超时是指客户端与服务器连接成功后,等待服务器发送数据的最大时间。如果在这个时间内客户端没有收到任何数据,就会认为读取操作超时并抛出异常。这通常发生在服务器处理请求的时间过长,或者网络传输延迟导致数据包迟迟未到达客户端。
- 写超时(Write Timeout): 写超时是指在客户端尝试向服务器发送数据时的最大等待时间。如果客户端在这段时间内未能完成数据的发送,就会认为写操作超时。这可能是因为网络速度慢或者服务器处理写入请求的速度慢。
以Tomcat为例:
可以在 文件中指定服务器的超时时间,如下所示:
其中参数在上文已提及,不再赘述。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/174364.html