当前位置: 首页 > article >正文

HTTP keep-alive和TCP keepalive详解

文章目录

    • 1、简介
    • 二、TCP keepalive
    • 三、HTTP keep-alive

1、简介

TCP是传输层的协议,HTTP是应用层的协议
HTTP中是keep-alive,TCP中是keepalive。这两个完全是两样不同东西

TCP keepalive是用来心跳包检测,是为了提高可靠性的;是由 TCP 层(内核态)实现的,称为 TCP 保活机制

HTTP keep-alive 是用来设置生效(开关),复用 TCP 连接,是为了提高性能的。是由应用层(用户态)实现的,称为 HTTP 长连接

在服务器端的保活
http保活 没有主动探测报文,无响应超时就关闭连接。tcp长连接 保活2小时后会主动探测,有响应则进入下一次保活周期。无响应则retry后关闭连接

二、TCP keepalive

TCP的保活机制就是用来解决在双方长时间未通讯时,得知对方还存活。这个机制称作:keepalive。保活机制默认是关闭的,TCP连接的任何一方都可打开此功能。
有三个主要配置参数用来控制保活功能:
·保活时间:tcp_keepalive_time

·探测时间间隔:tcp_keepalive_intvl

·探测循环次数上限:tcp_keepalive_probes

在探测过程中,客户主机必须处于下表中的4个状态之一。
在这里插入图片描述
在这里插入图片描述

三、HTTP keep-alive

HTTP协议简介中提到http协议是一个运行在TCP协议之上的无状态的应用层协议。它的特点是:客户端的每一次请求都要和服务端创建TCP连接,服务器响应后,断开TCP连接。下次客户端再有请求,则重新建立连接。

keep-alive机制:若开启后,在一次http请求中,服务器进行响应后,不再直接断开TCP连接,而是将TCP连接维持一段时间。在这段时间内,如果同一客户端再次向服务端发起http请求,便可以复用此TCP连接,向服务端发起请求,并重置timeout时间计数器,在接下来一段时间内还可以继续复用。这样无疑省略了反复创建和销毁TCP连接的损耗。


http://www.kler.cn/a/405796.html

相关文章:

  • 解决IDEA报包不存在,但实际存在的问题
  • 【数据库入门】关系型数据库入门及SQL语句的编写
  • 【实用数据】上市公司数字化转型双重差分准自然实验数据(2007-2022年)
  • 前端测试工具详解
  • VUE字符串转日期加天数
  • 游戏引擎学习第15天
  • npm/cnpm的使用
  • Day24 回溯算法part03
  • 什么是AOT技术?Java语言不同类型的JIT或AOT编译器?
  • android 实现答题功能
  • 046 购物车
  • Go语言基本类型转换
  • git使用(一)
  • 金融数据中心容灾“大咖说” | 美创科技赋能“灾备一体化”建设
  • STM32 ADC 读取模拟量
  • GitLab|数据迁移
  • DICOM图像处理:深入解析DICOM彩色图像中的Planar配置及其对像素数据解析处理的实现
  • [linux]linux c实现mac地址写入文件,实现删除和增加操作
  • windows下sqlplus连接到linux oracle不成功
  • dockerdsktop修改安装路径/k8s部署wordpress和ubuntu
  • 【论文阅读】Poison Forensics: Traceback of Data Poisoning Attacks in Neural Networks
  • 【大模型-智能体】AutoGen Studio测试和导出工作流程
  • C++:设计模式-单例模式
  • 如何优化Sql的查询性能?
  • 实景三维赋能国土空间智慧治理
  • Python爬虫中的IP封禁问题及其解决方案