您当前的位置:首页 > 电脑百科 > 网络技术 > 网络知识

TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

时间:2021-07-09 10:16:07  来源:公众号  作者:小林Coding

之前有读者问了我这么个问题:

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

大致问题是,TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

这是个好问题,应该有不少人都会搞混,因为这两个东西看上去太像了,很容易误以为是同一个东西。

事实上,这两个完全是两样不同东西,实现的层面也不同:

  • HTTP 的 Keep-Alive,是由应用层(用户态) 实现的,称为 HTTP 长连接;
  • TCP 的 Keepalive,是由 TCP 层(内核态) 实现的,称为 TCP 保活机制;

接下来,分别说说它们。

HTTP 的 Keep-Alive

HTTP 协议采用的是「请求-应答」的模式,也就是客户端发起了请求,服务端才会返回响应,一来一回这样子。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

请求-应答

由于 HTTP 是基于 TCP 传输协议实现的,客户端与服务端要进行 HTTP 通信前,需要先建立 TCP 连接,然后客户端发送 HTTP 请求,服务端收到后就返回响应,至此「请求-应答」的模式就完成了,随后就会释放 TCP 连接。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

一个 HTTP 请求

如果每次请求都要经历这样的过程:建立 TCP -> 请求资源 -> 响应资源 -> 释放连接,那么此方式就是 HTTP 短连接,如下图:

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

HTTP 短连接

这样实在太累人了,一次连接只能请求一次资源。

能不能在第一个 HTTP 请求完后,先不断开 TCP 连接,让后续的 HTTP 请求继续使用此连接?

当然可以,HTTP 的 Keep-Alive 就是实现了这个功能,可以使用同一个 TCP 连接来发送和接收多个 HTTP 请求/应答,避免了连接建立和释放的开销,这个方法称为 HTTP 长连接

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

HTTP 长连接

HTTP 长连接的特点是,只要任意一端没有明确提出断开连接,则保持 TCP 连接状态。

怎么才能使用 HTTP 的 Keep-Alive 功能?

在 HTTP 1.0 中默认是关闭的,如果浏览器要开启 Keep-Alive,它必须在请求的包头中添加:

Connection: Keep-Alive

然后当服务器收到请求,作出回应的时候,它也添加一个头在响应中:

Connection: Keep-Alive

这样做,连接就不会中断,而是保持连接。当客户端发送另一个请求时,它会使用同一个连接。这一直继续到客户端或服务器端提出断开连接。

从 HTTP 1.1 开始, 就默认是开启了 Keep-Alive,如果要关闭 Keep-Alive,需要在 HTTP 请求的包头里添加:

Connection:close

现在大多数浏览器都默认是使用 HTTP/1.1,所以 Keep-Alive 都是默认打开的。一旦客户端和服务端达成协议,那么长连接就建立好了。

HTTP 长连接不仅仅减少了 TCP 连接资源的开销,而且这给 HTTP 流水线技术提供了可实现的基础。

所谓的 HTTP 流水线,是客户端可以先一次性发送多个请求,而在发送过程中不需先等待服务器的回应,可以减少整体的响应时间。

举例来说,客户端需要请求两个资源。以前的做法是,在同一个 TCP 连接里面,先发送 A 请求,然后等待服务器做出回应,收到后再发出 B 请求。HTTP 流水线机制则允许客户端同时发出 A 请求和 B 请求。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

右边为 HTTP 流水线机制

但是服务器还是按照顺序响应,先回应 A 请求,完成后再回应 B 请求。

而且要等服务器响应完客户端第一批发送的请求后,客户端才能发出下一批的请求,也就说如果服务器响应的过程发生了阻塞,那么客户端就无法发出下一批的请求,此时就造成了「队头阻塞」的问题。

可能有的同学会问,如果使用了 HTTP 长连接,如果客户端完成一个 HTTP 请求后,就不再发起新的请求,此时这个 TCP 连接一直占用着不是挺浪费资源的吗?

对没错,所以为了避免资源浪费的情况,web 服务软件一般都会提供keepalive_timeout 参数,用来指定 HTTP 长连接的超时时间。

比如设置了 HTTP 长连接的超时时间是 60 秒,web 服务软件就会启动一个定时器,如果客户端在完后一个 HTTP 请求后,在 60 秒内都没有再发起新的请求,定时器的时间一到,就会触发回调函数来释放该连接。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

HTTP 长连接超时

TCP 的 Keepalive

TCP 的 Keepalive 这东西其实就是 TCP 的保活机制,它的工作原理我之前的文章写过,这里就直接贴下以前的内容。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

如果两端的 TCP 连接一直没有数据交互,达到了触发 TCP 保活机制的条件,那么内核里的 TCP 协议栈就会发送探测报文。

  • 如果对端程序是正常工作的。当 TCP 保活的探测报文发送给对端, 对端会正常响应,这样 TCP 保活时间会被重置,等待下一个 TCP 保活时间的到来。
  • 如果对端主机崩溃,或对端由于其他原因导致报文不可达。当 TCP 保活的探测报文发送给对端后,石沉大海,没有响应,连续几次,达到保活探测次数后,TCP 会报告该 TCP 连接已经死亡

所以,TCP 保活机制可以在双方没有数据交互的情况,通过探测报文,来确定对方的 TCP 连接是否存活,这个工作是在内核完成的。

阿里一面:TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?

 

TCP 保活机制

注意,应用程序若想使用 TCP 保活机制需要通过 socket 接口设置SO_KEEPALIVE 选项才能够生效,如果没有设置,那么就无法使用 TCP 保活机制。

总结

HTTP 的 Keep-Alive 也叫 HTTP 长连接,该功能是由「应用程序」实现的,可以使得用同一个 TCP 连接来发送和接收多个 HTTP 请求/应答,减少了 HTTP 短连接带来的多次 TCP 连接建立和释放的开销。

TCP 的 Keepalive 也叫 TCP 保活机制,该功能是由「内核」实现的,当客户端和服务端长达一定时间没有进行数据交互时,内核为了确保该连接是否还有效,就会发送探测报文,来检测对方是否还在线,然后来决定是否要关闭该连接。

原文链接:
https://mp.weixin.qq.com/s/25atTs4b-vORIx525ur_aw

作者:小林Coding

如果觉得本文对你有帮助,可以转发关注支持一下



Tags:Keepalive   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
1.TCP keepalive1.1.概念A keepalive (KA) is a message sent by one device to another to check that the link between the two is operating, or to prevent the link f...【详细内容】
2022-07-08  Tags: Keepalive  点击:(116)  评论:(0)  加入收藏
keepalive是基于vrrp协议实现接入层高可用组件,避免系统的单点故障。工作原理要想理解keepalive的原理,就需要理解vrrp协议的工作原理。概念解释:Vrrp(Virtual Router Redundanc...【详细内容】
2022-05-11  Tags: Keepalive  点击:(254)  评论:(0)  加入收藏
之前有读者问了我这么个问题: 大致问题是,TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?这是个好问题,应该有不少人都会搞混,因为这两个东西看上去太像了,很容易误以为是...【详细内容】
2021-07-09  Tags: Keepalive  点击:(166)  评论:(0)  加入收藏
我在看 go101 网站的 类型不安全指针[1](来源)[2] 一文时,偶然发现了runtime[3] 库的一个有趣的新方法 runtime.KeepAlive()[4] 的一个用法。刚开始我对于怎么使用它是很困惑...【详细内容】
2020-10-19  Tags: Keepalive  点击:(172)  评论:(0)  加入收藏
LVS简介LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统。LVS主要用于多服务器的负载均衡。它工作在网络层,可以实现高性能,高可用的服务器集...【详细内容】
2020-06-04  Tags: Keepalive  点击:(152)  评论:(0)  加入收藏
概述这是关于php进阶到架构之mysql进阶学习的系列课程:mysql+keepalive高可用方案操盘实战学习目标: 掌握mysql主从复制中的双主模式以及环境搭建 掌握keeplived的工作原理 My...【详细内容】
2020-05-19  Tags: Keepalive  点击:(103)  评论:(0)  加入收藏
本篇文章首先简单介绍了 TCP keepalive 的机制以及运用场景。接着介绍了 Go 语言中如何开启与设置 TCP keepalive。但是由于 Go 语言最上层的接口不够灵活,从而引出在 Go 语...【详细内容】
2019-10-22  Tags: Keepalive  点击:(311)  评论:(0)  加入收藏
1.keepalived简介Keepalived是一个基于VRRP协议来实现的WEB服务高可用方案,可以利用其来避免单点故障。使用多台节点安装keepalived。其他的节点用来提供真实的服务,同样的,他...【详细内容】
2019-09-24  Tags: Keepalive  点击:(265)  评论:(0)  加入收藏
▌简易百科推荐
上文对于网络问题分析的还不够精细,比如有时候网络资源可能没有达到瓶颈,并且没有丢包产生,但这个时候网络传输速率就是很慢或者是有丢包产生了,但是却无法知道丢的是具体哪个包...【详细内容】
2022-10-31  平凡人笔记  今日头条  Tags:TCP   点击:(10)  评论:(0)  加入收藏
知识网络是知识参与者之间的社会网络。能够实现个人、组织与组织外部的知识创造与传递,人们透过知识网络进行信息合作与交流。目标是把技术与人连接起来,实现智力资本、结构资...【详细内容】
2022-10-31  寒江独赢  今日头条  Tags:无线网络   点击:(2)  评论:(0)  加入收藏
背景介绍在服务刚启动的时候,服务的运行状态并没有达到最佳,如果一下子将流量提升到日常运行的状态,会存在大量的请求超时。 为什么服务刚启动的时候,服务不是最佳状态呢? Java应...【详细内容】
2022-10-24  大禹的足迹  今日头条  Tags:网关   点击:(10)  评论:(0)  加入收藏
经过《如果让你来设计网络》这篇文章中的一番折腾,只要你知道另一位伙伴 B 的 IP 地址,且你们之间的网络是通的,无论多远,你都可以将一个数据包发送给你的伙伴 B...【详细内容】
2022-10-21  热爱生活的小胖胖  知乎  Tags:TCP   点击:(48)  评论:(0)  加入收藏
日常开发中我们出于保证连接的稳定性的目的,将应用拆分成了「主进程」和「通讯进程」,并为二者定义了相互通信的接口。即便如此,我们也只是实现了客户端一侧的进程间通信,而要实...【详细内容】
2022-10-20  音视频开发老舅  今日头条  Tags:WebSocket   点击:(11)  评论:(0)  加入收藏
前言上次有写过一篇《20张图深度详解MAC地址表、ARP表、路由表》的文章,里面有提到了MAC地址表。那么什么是MAC地址表?MAC地址表有什么作用?MAC地址表里面包含了哪些要素?今天...【详细内容】
2022-10-20   智能改变世界   网易号  Tags:MAC地址   点击:(25)  评论:(0)  加入收藏
【CSDN 编者按】API是Application Program Interface,应用程序连接接口的缩写,作为数据传输流转的重要通道,API网关更成为云原生时代的重要入口。作者 | 温铭,Apache APISIX PMC...【详细内容】
2022-10-18    CSDN  Tags:API 网关   点击:(8)  评论:(0)  加入收藏
P地址和MAC地址可以类比生活中寄快递的过程。在整个网络中数据被封装成数据报文进行发送,就像我们生活中寄快递时将物品放进包裹中。而数据在路由器之间的跳转也可以看作是不...【详细内容】
2022-10-16  互联网资讯看板    Tags:MAC 地址   点击:(25)  评论:(0)  加入收藏
很多朋友在生活中都会遇到这个问题,为什么自己的网络明明是千兆光纤或者百兆光纤的,而且连接的设备也很少,但是网速却非常慢呢?这是怎么回事呢?其实一般遇到这样的问题时,我们就需...【详细内容】
2022-10-13   小俊分享   网易号  Tags:路由器   点击:(29)  评论:(0)  加入收藏
现在许多地方都提供免费公共WiFi。作为使用服务的额外好处,机场,酒店和咖啡馆都在提供免费的网络连接。对于许多人来说,能够在旅途中连接到免费的互联网似乎是理想的选择。能够...【详细内容】
2022-10-11  小徐谈区块链  今日头条  Tags:Wifi   点击:(31)  评论:(0)  加入收藏
站内最新
站内热门
站内头条