http1.1 的默认长连接 Connection: keep-alive 与 TCP KeepAlive 之间区别

HTTP 长连接,也称为 HTTP 持久连接(HTTP Persistent Connection)或 HTTP 连接重用,是一种在 HTTP 协议中实现的机制。

在传统的 HTTP 通信中,每个 HTTP 请求和响应都会伴随着 TCP 连接的建立和关闭,这在高并发场景下会增加网络开销和延迟。

而 HTTP 长连接则允许客户端和服务器在完成一次 HTTP 事务后保持 TCP 连接打开,以便后续的HTTP请求可以复用同一连接,而不是每次都创建新的连接。

核心意图是在一段时间内复用TCP连接

以下是一些关于HTTP长连接的关键点:

连接保持:在HTTP/1.1及更高版本中,默认启用长连接。响应头中的 Connection: keep-alive 指示客户端和服务器都应尝试保持连接开放。

如果要关闭 Keep-Alive,需要在 HTTP 请求的包头里添加: Connection :close

现在大多数浏览器都默认是使用 HTTP/1.1,所以 Keep-Alive 都是默认打开的。

性能优化:通过减少TCP连接的创建和销毁,长连接减少了网络开销,降低了延迟,并提高了整体性能。

Keep-Alive 头:Keep-Alive 头通常用于设置连接的超时时间,即连接在无活动多久后关闭。如果不指定,连接可能会在一段时间后自动关闭,或者在服务器或客户端选择关闭时关闭。

资源管理:虽然长连接可以提高效率,但服务器需要管理这些持续连接的资源,防止过多的开放连接耗尽服务器资源。

适用性:并非所有HTTP请求都适合使用长连接,例如,如果请求之间有安全隔离的需求,或者服务器需要释放资源,可能会选择关闭连接。

要想做到 Client 与 Nginx 之间保持长连接,需要:

- Client 发送过来的 HTTP 请求 header 要求携带 "keep-alive"

- Nginx 设置支持 keepalive

Nginx中的 keepalive 配置项:keepalive_timeout

Nginx 使用 keepalive_timeout 来指定 KeepAlive 的超时时间(timeout),指定每个 TCP 连接最多可以保持多长时间。Nginx 的默认值是 75 秒,有些浏览器最多只保持 60 秒,所以可以设定为 60 秒。若将它设置为 0,就禁止了 keepalive 连接。

注意和 TCP 的 KeepAlive 区别对待:

HTTP 协议的 KeepAlive 意图在于连接复用,同一个连接上串行方式传递请求-响应数据。
TCP 的 KeepAlive 机制意图在于保活、心跳,检测连接错误。

Linux 操作系统中设置 KeepAlive 相关参数(/etc/sysctl.conf):

net.ipv4.tcp_keepalive_time=90

net.ipv4.tcp_keepalive_intvl=15

net.ipv4.tcp_keepalive_probes=2

Link:https://www.cnblogs.com/farwish/p/18233744

相关推荐
basketball6166 小时前
HTTP协议返回状态码总结
网络·网络协议·http
是Yu欸10 小时前
CC-Switch 零基础保姆级教程1(2026 最新版)
网络·人工智能·网络协议·http·大模型·claude·claude desktop
夏天测11 小时前
【高危漏洞通告】NGINX ngx_http_rewrite_module 堆缓冲区溢出漏洞;详解与修复方案
运维·nginx·http
FallenQu11 小时前
【漏洞】CVE-2026-42945:NGINX ngx_http_rewrite_module 堆缓冲区溢出深度分析
运维·nginx·http
yqcoder14 小时前
服务器的“红绿灯”:图解常见 HTTP 状态码
运维·服务器·http
薛定谔的猫喵喵2 天前
【从 HTTP 到 HTTPS】Flask 多项目迁移到 Nginx 子路径完整实战
python·nginx·http·https·flask·ssl
曾阿伦2 天前
requests HTTP 库解析
网络·网络协议·http
福大大架构师每日一题2 天前
nginx 1.31.1 发布:一次安全修复驱动的主线升级,涉及 Rewrite、HTTP/2、Mail、MP4 与工作流修正
nginx·安全·http
catchadmin2 天前
TrueAsync Server 为 PHP 带来了原生的高性能 HTTP 服务器
服务器·http·php
你觉得脆皮鸡好吃吗2 天前
XSS渗透 COOKIE
网络·http·okhttp·网络安全学习