这些年http协议的优缺点

HTTP 超文本传输协议 /0.9

http0.9是最原始的http的版本,在1991年发布的一种简单的基于TCP的超文本传输协议

  1. 它没有请求头、响应体、状态码等等,只有请求行。
  2. 并且只能发送GET请求,客户端发送GET请求,服务端会响应整个HTML文档。
  3. 表示它只能支持传输html一种类型的资源。
  4. 以 ASCII 字符流的编码方式进行传输

HTTP /1.0

随着互联网的发展,0.9版本已经无法支持多种资源类型传输,因此http1.0基于0.9进行了一次升级

  1. 升级后就可以传输js,css,图片,音频...
  2. 支持请求头、响应体、状态码等等,多种请求方式。
  3. 持久连接(需要等待前一个连接响应),需要在请求头中包含Connection: keep-alive
  • 请求头

    响应内容类型(压缩): accept:text/html

    支持的编码方式:accept-encoding:gzip deflate Brotli;

    首选语言: accept-language:zh-CN

  • 响应头

    • 1.0 Content-Length:1024

      后端动态内容生成,无法确定数据大小

    • content-type:text/html

    • 告诉客户端压缩方式:accept-encoding:br;

  • 为了传输不同的类型资源而诞生

HTTP /1.1

  • 默认持久连接,可以在一个连接同时发送多个请求,减轻了服务器的负担。

  • 同时最多维护6个持久连接。

  • 缺点:建立长连接导致队头阻塞

    1. 前一个http请求没有得到响应,后一个http请求无法发送。
  • HOST头部

    必须,使一个服务器托管多个域名。

  • 响应头:

    相较于1.0的后端动态数据内容生成,无法确定数据大小, 1.1的 Chunk transfer机制:将资源文件处理成若干个数据块并编辑数据块的大小,最后发送一个标记为0的数据块来告诉客户端,资源传输完成。

HTTP /2.0

  • 1.1 缺点:
    1. 队头堵塞
    2. 带宽利用率低 (1)同时开启多条持久连接,相互之间会竞争带宽 (2)TCP的慢启动拖延了首页首次渲染的时间 (3)队头阻塞 (前一个http请求被阻塞5s,后一个http请求又不能发送,那么该5s内带宽白白浪费)

为了解决带宽利用率低的问题,2.0

  • 一次只能维护一个TCP长连接

  • 多路复用(解决队头阻塞)

    将每一个请求处理成一帧一帧的请求片段(二进制分帧层),并给每一帧打上标记,服务端接收到所有的帧之后,会将标记相同的帧合并为一个完整请求,再响应该请求,响应体同样处理成一帧一帧传输

HTTPS HTTP + TLS(加密协议)

  • 对称加密: 双方都要拥有相同的密钥,密钥用于数据的加密和解密,如何让双方都具有相同的密钥就变成了一个问题 使用网络传输,一旦在传输密钥的阶段被截获,接下来的加密就没有意义

  • 非对称加密: 首先服务端创建公钥和私钥,并将公钥发布出去,那么客户端也就知道了公钥,客户端创建一个密钥, 通过公钥加密将密钥传给服务端,服务端通过独有的私钥进行解密得到正确的密钥。

先用非对称加密让客户端和服务端具有相同的密钥,然后再进行对称加密

HTTP /3.0

  • 2.0的缺点

    1. TCP队头阻塞:当存在数据包丢失时,TCP会重传一个新的包,在新包传递前,后续的数据包会被暂停传输
    2. TCP握手也是时间开销
  • TCP协议僵化

    由于http采用的QUIC协议,但在一些网络环境中,可能依然会受到 TCP 协议特性的限制和影响。

  • 改UDP ---QUIC协议(基于UDP)

    1. 在UDP上实现了TCP的拥塞控制,可靠性传输 (拥塞控制:网络拥塞就降低发送速率)
    2. 集成了TLS加密
    3. 实现了多路复用:单个连接发送多个请求
    4. 快速握手
相关推荐
橙子家1 小时前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
最新资讯动态2 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态2 小时前
游戏出海,从产品走向体系
前端
最新资讯动态2 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态2 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝4 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen4 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒5 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
徐小夕6 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
一份执念6 小时前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序