0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

字节一面:HTTP长连接和TCP长连接有区别?

小林coding ? 来源:小林coding ? 作者:小林coding ? 2022-12-02 14:00 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

大家好,我是小林。

之前有位读者私信我,他在字节面试时,被问到这两个问题:

第一个问题:MySQL 的 NULL 值是怎么存放的?

第二个问题:HTTP 长连接和 TCP 长连接有什么区别?

第一个问题,主要是考核你是否清楚 MySQL 一条记录是怎么存储的,我在前几天已经写了一篇文章讲解了,还没看过的同学,可以去看这篇:字节一面:MySQL 的 NULL 值是怎么存放的?

第二问题,其实是在问 HTTP 的 Keep-Alive 和 TCP 的 Keepalive 有什么区别?

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

如果认真读过我网站上图解网络系列文章的同学,应该这个问题你们都会,因为我之前就写过。

不过,应该也有不少同学,看过后忘记了,这次就带大家重新复习一波。

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

HTTP 的 Keep-Alive,是由应用层(用户态)实现的,称为 HTTP 长连接;

TCP 的 Keepalive,是由TCP 层(内核态)实现的,称为 TCP 保活机制;

接下来,分别说说它们。

HTTP 的 Keep-Alive

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

3e26a8d2-7205-11ed-8abf-dac502259ad0.png

请求-应答

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

3e32a4fc-7205-11ed-8abf-dac502259ad0.png

一个 HTTP 请求

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

3e48c390-7205-11ed-8abf-dac502259ad0.png

HTTP 短连接

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

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

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

3e70a324-7205-11ed-8abf-dac502259ad0.png

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 请求。

3e8df00a-7205-11ed-8abf-dac502259ad0.png

右边为 HTTP 流水线机制

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

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

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

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

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

3eb55dac-7205-11ed-8abf-dac502259ad0.png

HTTP 长连接超时

TCP 的 Keepalive

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

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

如果对端程序是正常工作的。当 TCP 保活的探测报文发送给对端, 对端会正常响应,这样TCP 保活时间会被重置,等待下一个 TCP 保活时间的到来。

如果对端主机崩溃,或对端由于其他原因导致报文不可达。当 TCP 保活的探测报文发送给对端后,石沉大海,没有响应,连续几次,达到保活探测次数后,TCP 会报告该 TCP 连接已经死亡。

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

3ed5f9d6-7205-11ed-8abf-dac502259ad0.png

TCP 保活机制

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

总结

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

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

历史好文:

字节一面:TCP 三次握手,问的好细!

美团二面:TCP 四次挥手,可以变成三次吗?

字节一面:服务端挂了,客户端的 TCP 连接还在吗?

字节一面:HTTPS 一定安全可靠吗?

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HTTP
    +关注

    关注

    0

    文章

    526

    浏览量

    33841
  • TCP
    TCP
    +关注

    关注

    8

    文章

    1410

    浏览量

    81609
  • MySQL
    +关注

    关注

    1

    文章

    875

    浏览量

    28244
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Modbus TCP连接多个客户端解决方法-深圳市振鑫通信科技

    ZP-MBS008多主站模块是实现Modbus-TCP连接多个客户端或者服务器通讯设备
    的头像 发表于 06-25 11:07 ?669次阅读
    Modbus <b class='flag-5'>TCP</b><b class='flag-5'>连接</b>多个客户端解决方法-深圳市振鑫通信科技

    网络光纤线可以接吗?

    网络光纤线可以接,但接长过程需要专业的设备、技术和操作规范,且接后可能会对光纤传输性能产生定影响。以下是关于网络光纤线接的详细说明: 接长方法 光纤熔接 原理:使用光纤熔接机,
    的头像 发表于 05-07 10:42 ?504次阅读

    SMA,3.5mm,2.92mm 连接器的性能区别是什么?

    器的性能区别是什么呢?接下来德索精密工业工程师为大家科普下SMA,3.5mm,2.92mm 连接器的性能区别是什么。
    的头像 发表于 03-01 09:12 ?857次阅读
    SMA,3.5mm,2.92mm <b class='flag-5'>连接</b>器的性能<b class='flag-5'>区别</b>是什么?

    调试TCP协议连接的常用工具

    在网络通信中,TCP(传输控制协议)是种面向连接的、可靠的、基于字节流的传输层通信协议。调试TCP连接
    的头像 发表于 01-22 09:59 ?4424次阅读

    TCP协议与UDP协议的区别

    1. 连接TCP(传输控制协议) : 面向连接 :在数据传输之前,TCP需要建立连接,这
    的头像 发表于 01-22 09:44 ?1009次阅读

    TCP三次握手与连接建立的关系

    在计算机网络中,TCP(传输控制协议)是种面向连接的、可靠的、基于字节流的传输层通信协议。它负责在两个主机之间建立、维护和终止连接,确保数
    的头像 发表于 01-06 09:09 ?867次阅读

    TCP三次握手与UDP的区别

    连接管理、可靠性、效率等方面有着显著的区别。 1. TCP三次握手 TCP种面向连接的、可
    的头像 发表于 01-03 17:35 ?964次阅读

    HTTP 1.1 和 HTTP 2.0 的区别

    2015年正式成为互联网标准。以下是HTTP/1.1和HTTP/2之间的些主要区别: 1. 多路复用(Multiplexing) HTTP
    的头像 发表于 12-30 09:25 ?1380次阅读

    工业连接器与传统连接器的区别

    工业连接器与传统连接器的区别主要体现在以下几个方面: 1. 环境适应性 工业连接器: 耐温性: 工业连接器通常需要在极端的温度条件下工作,从
    的头像 发表于 12-29 10:20 ?695次阅读

    测径仪 测测仪是如何应用在卷烟生产中的?

    关键字:卷烟测径仪,卷烟测仪,烟草测径仪,烟草测仪,烟草机械测径仪,卷烟设备,烟草设备, 测径仪和测仪在卷烟生产中发挥着至关重要的作用,它们能够精确测量卷烟的物理尺寸,确保产品质量的
    发表于 11-13 13:58

    电缆连接ADS8410/13

    电子发烧友网站提供《用电缆连接ADS8410/13.pdf》资料免费下载
    发表于 10-22 09:42 ?0次下载
    用<b class='flag-5'>长</b>电缆<b class='flag-5'>连接</b>ADS8410/13

    TPA311X系列芯片的SYNC如果是做成系统的是否需要连接连接于不连接有什么优缺点?

    TPA311X系列芯片的SYNC如果是做成系统的是否需要连接连接于不连接有什么优缺点?如下图所示
    发表于 10-14 06:49

    TCP协议是什么

    ,应用层之下,为各种应用提供可靠的、面向连接的、基于字节流的传输服务。本文将详细解析TCP协议的定义、工作原理、主要特点及其在各种应用场景中的重要作用。 定义与基本原理 TCP协议是
    的头像 发表于 10-09 13:54 ?2002次阅读

    网线不够可以接吗

    网线不够是可以接的。当网线长度不足以覆盖所需连接的距离时,可以通过几种方法来延长网线。 网线连接器(耦合器):使用网线连接器(也称为耦合器或中继器)可以将两根网线
    的头像 发表于 09-12 09:33 ?5104次阅读

    工业相机测仪的组成部分

    处理,以保障工业相机采集数据的准确性。 (四)软件部分 图像处理技术是利用计算机来处理、分析和理解视觉信息的项技术。图像处理技术的数学模型主要有正交模型、统计模型、预测模型等。型材测系统是在正交模型
    发表于 08-27 17:45