20、HTTP的Keep-Alive是什么?TCP 的 Keepalive 和 HTTP 的 Keep-Alive 是一个东西吗?【中高频】

  • HTTP 的Keep-Alive,是由 应用层 实现的,称为 HTTP长连接。在HTTP短连接中,每次发送请求都要经历TCP的三次握手和四次挥手。若发送下一个请求,还需要重新再建立TCP连接。而 HTTP长连接可以在同一个 TCP连接中 发送和接收多个HTTP请求和应答, 也就是说,只要任意一端没有明确提出断开连接,则TCP保持连接,从而减少了TCP握手和挥手的时间。

    • 短连接:
    • 长连接:

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

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

        Connection: Keep-Alive

      • 然后当服务器收到请求,作出回应的时候,它也要在响应报文中添加响应中:

        Connection: Keep-Alive

      这样就会变成 HTTP 长连接
      2. 在 HTTP 1.1 中

      • 默认开启 Keep-Alive,如果要关闭 Keep-Alive,需要在 HTTP 请求报文里添加:

        Connection: close

      现在大多数浏览器都默认是使用 HTTP/1.1,所以 Keep-Alive 都是默认打开的。客户端和服务端一开始就会建立长连接。

  • TCP 的 Keepalive,是由 传输层 实现的,称为 TCP保活定时器,用于 探测对端是否存活,从而判断是否保持连接。当TCP连接建立后,如果一段时间内 没有传输数据,TCP keepalive就会多次发送 探测包 来检测 对端是否存活。在发送一定数量的探测包之后,如果依然没有获得响应,则会关闭TCP连接

  • 应用程序若想使用 TCP 保活机制需要通过 socket 接口设置 SO_KEEPALIVE 选项才能够生效,如果没有设置,那么就无法使用 TCP 保活机制
相关推荐
运维儿2 分钟前
5.VLAN的高级技术MUX VLANSuper VLANVLAN Mapping
网络·网络协议·tcp/ip·linux 网络·云计算网络
IP老炮不瞎唠2 分钟前
为什么Python爬虫需要代理 IP?原理与应用详解
爬虫·python·tcp/ip
vortex543 分钟前
基于资源约束的委派 (RBCD) 利用细节
网络·网络协议·网络安全·内网渗透·ad域
taxunjishu1 小时前
速冻食品物联网网关应用 DeviceNet转Profinet提升产线协同效率
物联网·网络协议·自动化
AI_Claude_code1 小时前
网络基础回顾:DNS、IP封锁与HTTP/S协议关键点
网络·爬虫·python·tcp/ip·http·爬山算法·安全架构
大数据新鸟1 小时前
协议值TCP
服务器·网络·tcp/ip
“愿你如星辰如月”1 小时前
从零构建高性能 Reactor 服务器:
linux·服务器·c++·websocket·tcp/ip
韭菜钟11 小时前
WIndows下一键切换网卡IP脚本
windows·网络协议·tcp/ip
上海云盾-小余15 小时前
DDoS 攻击全解析:常见类型识别与分层防御思路
网络协议·tcp/ip·安全·ddos
卤炖阑尾炎15 小时前
Python 网络编程实战:从 TCP/UDP 基础到高并发服务器开发
网络·python·tcp/ip