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

http1,connection,keep,alive,tcp,keepalive · 浏览次数 : 0

小编点评

HTTP长连接是一种在HTTP协议中实现的机制,它允许客户端和服务器在完成一次HTTP事务后保持TCP连接打开,以便后续的HTTP请求可以复用同一连接,从而减少了网络开销和延迟。HTTP长连接的核心意图是在一段时间内复用TCP连接。 以下是关于HTTP长连接的一些关键点: 1. 连接保持:在HTTP/1.1及更高版本中,默认启用长连接。响应头中的Connection: keep-alive指示客户端和服务器都应尝试保持连接开放。 2. 关闭Keep-Alive:如果要关闭Keep-Alive,需要在HTTP请求的包头里添加:Connection :close 3. 浏览器默认设置:现在大多数浏览器都默认是使用HTTP/1.1,所以Keep-Alive都是默认打开的。 4. 性能优化:通过减少TCP连接的创建和销毁,长连接减少了网络开销,降低了延迟,并提高了整体性能。 5. Keep-Alive头:Keep-Alive头通常用于设置连接的超时时间,即连接在无活动多久后关闭。如果不指定,连接可能会在一段时间后自动关闭,或者在服务器或客户端选择关闭时关闭。 6. 资源管理:服务器需要管理这些持续连接的资源,防止过多的开放连接耗尽服务器资源。 7. 适用性:并非所有HTTP请求都适合使用长连接,例如,如果请求之间有安全隔离的需求,或者服务器需要释放资源,可能会选择关闭连接。 要想做到Client与Nginx之间保持长连接,需要: - Client发送过来的HTTP请求header要求携带"keep-alive" - Nginx设置支持keepalive Nginx中的keepalive配置项: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。

正文

 

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

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

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

HTTP 长连接,也称为 HTTP 持久连接(HTTP Persistent Connection)或 HTTP 连接重用,是一种在 HTTP 协议中实现的机制。 在传统的 HTTP 通信中,每个 HTTP 请求和响应都会伴随着 TCP 连接的建立和关闭,这在高并发场景下会增加网络开销和延迟。 而

nginx在代理到upstream时转换http1.1为http1.0,长连接转为短连接

# nginx在代理到upstream时的默认行为 最近准备用openresty替换nginx,替换的效果当然是需要保证效果和nginx一致,不然可能就会导致线上在用的服务出现问题。 替换成openresty后,在本地进行了一个请求,header如下: ```http POST /servlet/j

弹性数据库连接池探活策略调研(一)——HikariCP

# 调研背景: 数据库连接建立是比较昂贵的操作(至少对于 OLTP),不仅要建立 TCP 连接外还需要进行连接鉴权操作,所以客户端通常会把数据库连接保存到连接池中进行复用。连接池维护到弹性数据库(JED)的长连接,弹性数据库默认不会主动关闭客户端连接(除非报错),但一般客户端到弹性数据库之间还会有负

[转帖]postgresql 的一些变量和密码文件

https://www.cnblogs.com/ctypyb2002/p/9792872.html 一些变量 下列环境变量能被用于选择默认的连接参数值,如果调用代码没有直接指定值,它们将被用于PQconnectdb、PQsetdbLogin和PQsetdb。例如,这些有助于防止数据库连接信息被硬编码

【转帖】linux环境下使用route指令设置多个网络连接的优先级(通过修改路由表的默认网关条目)

1. 背景 在生活中的会经常遇见一台PC同时连接多个网络的场景.最典型的,一台笔记本可以同时连接一个无线网(手机热点)和一个有线网(以太网).linux和window操作系统在默认情况都会使用最早连接的网络进行互联网访问.如果我们想切换到另一个网络进行互联网访问,最粗暴的方法就是断开最先连接的网络,

[转帖]tcp_tw_reuse、tcp_tw_recycle 使用场景及注意事项

linux TIME_WAIT 相关参数: net.ipv4.tcp_tw_reuse = 0 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭net.ipv4.tcp_tw_recycle = 0 表示开启TCP连接中TIME-WAIT socket

SpringBoot项目实现日志打印SQL明细(包括SQL语句和参数)几种方式

前言 我们在开发项目的时候,都会连接数据库。有时候遇到问题需要根据我们编写的SQL进行分析,但如果不进行一些开发或者配置的话,这些SQL是不会打印到控制台的,它们默认是隐藏的。下面给大家介绍几种常用的方法。 第一种、代码形式 Mybatis框架是Java程序员最常用的数据库映射框架,MyBatis

Linux:进程模型和进程管理

在Linux系统中,执行一个程序或命令就可以触发一个进程,系统会给予这个进程一个ID,称为PID,同时根据触发这个进程的用户与相关属性关系,基于这个PID一组有效的权限设置。举个常见的例子,我们要操作系统的时候通常是利用ssh连接程序或直接在主机上登录,然后获取shell。默认的shell是bash,对应的路径为/bin/bash,那么同时间的每个人登录都是执行/bin/bash,不过每个人获取的

docker网络 bridge 与overlay 模式

转载请注明出处: 1.bridge网络模式 1.1工作原理: 在Bridge模式中,Docker通过创建一个虚拟网络桥接器(bridge)将容器连接到主机上的物理网络接口。每个容器都会被分配一个IP地址,使得它们可以相互通信,并且可以与主机进行通信。 Docker的Bridge网络模式是默认的网络配

性能提升-如何设置Windows操作系统TIME_WAIT状态的TCP连接快速回收时间?

大规模Windows环境下,采用Nginx反向代理服务后,操作系统会产生较多TIME_WAIT的TCP(Transmission Control Protocol)连接,操作系统默认TIME_WAIT的TCP连接回收时间是4分钟,TCP默认动态端口范围为开始端口49152,结束端口65535。这样会