TCP Keepalive 和 HTTP Keep-Aliv

HTTP的Keep-Alive

在http1.0的版本中,它是基于请求-应答模型和TCP协议的,也就是在建立TCP连接后,客户端发送一次请求并且接收到响应后,就会立马断开TCP连接,称为HTTP短连接,这种方式比较耗费时间以及浪费资源。

keep-alive就是用来解决短连接,实现长连接的,也就是在一个TCP连接中,可以发送多个HTTP请求、接收多个响应。要开启keep-alive,就是往请求头和响应头中都添加Connection:keep-alive字段

  • 1.0默认是关闭,如果要开启,游览器就需要往请求头中添加Connection:keep-alive字段,服务端收到后也要往响应头中添加Connection:keep-alive字段
  • 1.1默认是开启的,如果要关闭,游览器中的请求头添加Connection:close字段

同时,为了避免长时间占用TCP连接而不进行请求的发送,造成的资源浪费,服务端会有一个keepalive-timeout参数来控制HTTP长连接的超时时间,如果在超时时间内都没有请求发送,服务端就会主动断开连接

TCP的keepalive

TCP的keepalive实际上是TCP的保活机制,由内核实现发送探测报文,用来确定tcp连接是否还有效。

当TCP连接的两端长时间没有进行数据交互,达到了触发TCP保活机制的条件,内核就会发送探测报文

  • 如果能收到响应,说明连接是正常的,tcp的保活时间就会重置

  • 如果收不到响应,说明连接是不正常的,有可能是对方的主机宕机了,或者是其他原因导致的报文不可达,再决定是否关闭该TCP连接。

    (注意这里是对方主机宕机,而不是对方进程崩溃。如果是进程崩溃,操作系统在回收资源的时候会发送FIN报文,来告知对方关闭TCP连接。而主机宕机,对方是感知不到的)

总结

  • HTTP的keep-alive是HTTP的长连接,由应用程序实现,能够在一个TCP连接发送和接收多个请求和响应,减少HTTP短连接带来的多次TCP连接建立和释放的开销

  • TCP的keep-alive是TCP的保活机制,由内核实现,当客户端和服务端长时间没有通信时,内核为了确定连接是否还有效,就会发送探测报文来检测连接是否正常

相关推荐
Johny_Zhao6 小时前
CentOS Stream 8 高可用 Kuboard 部署方案
linux·网络·python·网络安全·docker·信息安全·kubernetes·云计算·shell·yum源·系统运维·kuboard
uyeonashi9 小时前
【QT系统相关】QT网络
开发语言·网络·c++·qt
YUNYINGXIA10 小时前
Nginx+keepalived主从,双主架构
网络·nginx·keepalived
hie9889412 小时前
常见内核TCP参数描述与配置
服务器·网络·tcp/ip
大咖分享课13 小时前
零信任安全技术深度解析:技术架构与最佳实践
网络·安全架构·零信任安全
靡樊13 小时前
应用层协议HTTP
网络·网络协议·http
上海云盾第一敬业销售14 小时前
高防IP是怎么防御的?高防IP的防御步骤又有哪些?
运维·网络·安全
magic 24514 小时前
@RequestHeader(“Authorization“) 解析:HTTP 请求头中的 Authorization 字段
网络·网络协议·http
涟漪海洋1 天前
基于Netty的UDPServer端和Client端解决正向隔离网闸数据透传问题
网络
国际云,接待1 天前
微软云注册被阻止怎么解决?
服务器·网络·microsoft·云原生·微软·云计算