http2解决了哪些问题_简述http2的优点
myzbx 2025-09-01 09:57 5 浏览
HTTP/2(最初称为 SPDY)是 HTTP 协议的第二个主要版本,它在 HTTP/1.1 的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是 HTTP/2 主要解决的问题:
队头阻塞(Head-of-Line Blocking)问题:
- HTTP/1.1 的问题:在 HTTP/1.1 中,虽然可以建立多个 TCP 连接来并行请求资源,但每个连接内部的请求是串行处理的。如果一个请求的响应很慢,它会阻塞后续请求的响应(尤其是在使用 keep-alive 时),造成“队头阻塞”。
- HTTP/2 的解决方案:引入了多路复用(Multiplexing)。所有请求和响应都在同一个 TCP 连接上通过流(Stream)、消息(Message) 和帧(Frame) 的分层结构并行传输。每个流都有唯一的 ID,帧可以交错发送并重新组装,从而彻底解决了应用层(HTTP层)连接内部的队头阻塞问题。
减少延迟和提升页面加载速度:
- HTTP/1.1 的问题:为了克服串行请求的限制,浏览器通常会为一个站点建立 6-8 个并发 TCP 连接。这不仅增加了建立连接的开销(TCP 握手、TLS 握手),还可能导致网络拥塞。
- HTTP/2 的解决方案:通过多路复用,一个 TCP 连接就足以处理所有资源的并行请求和响应。这大大减少了连接建立的开销和延迟,提高了网络资源的利用率,从而显著提升了页面加载速度。
头部信息冗余和传输开销大:
- HTTP/1.1 的问题:HTTP 头部信息(如 Cookie、User-Agent 等)通常很大且重复,每次请求都必须完整发送,占用了大量带宽,尤其在移动端或高延迟网络中影响明显。
- HTTP/2 的解决方案:采用了HPACK 压缩算法对 HTTP 头部进行压缩。客户端和服务器都维护一个头部字段的索引表,只传输索引和增量信息,极大地减少了头部传输的数据量。
服务器被动响应,无法主动推送资源:
- HTTP/1.1 的问题:服务器只能被动地响应客户端的请求。如果客户端请求一个 HTML 页面,服务器返回后,客户端需要再次请求其中的 CSS、JavaScript、图片等资源,增加了往返次数(RTT)。
- HTTP/2 的解决方案:引入了服务器推送(Server Push) 功能。服务器可以在客户端请求一个资源时,主动将它预测客户端接下来会需要的资源(如 HTML 页面依赖的 CSS 和 JS 文件)一并推送给客户端,减少了客户端发现和请求这些资源的延迟。
请求效率低下:
- HTTP/1.1 的问题:请求必须等待响应才能发出下一个(在单个连接上),或者需要复杂的连接管理来实现并发。
- HTTP/2 的解决方案:除了多路复用带来的并行性,HTTP/2 还允许客户端发送优先级(Priority) 信息,告知服务器哪些资源更重要,需要优先处理和传输,从而更智能地分配带宽。
总结来说,HTTP/2 的核心改进在于:
- 多路复用:解决队头阻塞,实现真正的并行。
- 二进制分帧层:将消息分解为更小的帧,支持多路复用和优先级。
- 头部压缩(HPACK):减少不必要的数据传输。
- 服务器推送:允许服务器主动发送资源。
- 请求优先级:优化资源传输顺序。
相关推荐
- 半导体行业术语缩写词典总结-JKL_半导体词汇缩写表
-
作为半导体行业新人来说,最痛苦的莫过于各种缩写词术语了,有的缩写词一样但是会有不同的解释。这里作者给大家整理了部分术语词典,后面会按照更新顺序一一分享出来。废话不多说,直接开始,如有遗漏,欢迎大家在评...
- JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech
-
ToraOne,thesecond-generationmultidimensionaltactilehumanoidrobotdevelopedbyPaXiniTechTMTPOS...
- Hong Kong's Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants
-
AI-generatedimageTMTPOST--StrollthroughthestreetsofHongKongtoday,anditmightfeellikey...
- http2解决了哪些问题_简述http2的优点
-
HTTP/2(最初称为SPDY)是HTTP协议的第二个主要版本,它在HTTP/1.1的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是HTTP/2主要解决的问题:队头阻...
- China's economy stays strong and vital amid pressure
-
Peoplevisitthe4thChina-CEECExpo&InternationalConsumerGoodsFairinNingbo,eastChina's...
- JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire
-
TMTPOST--JD.comhasunveiledplanstoacquireGermany’sCeconomyAG—theparentofEurope’sleading...
- 深入剖析 Java 中的装饰器设计模式:原理、应用与实践
-
在Java软件开发的广阔天地里,设计模式犹如璀璨星辰,照亮我们构建高效、可维护系统的道路。今天,让我们聚焦于其中一颗闪耀的星——装饰器设计模式,深入探究它的奥秘,看看如何利用它为我们的代码赋予...
- 组合模式应用-适配器模式_适配器组件
-
写在前面Hello,我是易元,这篇文章是我学习设计模式时的笔记和心得体会。如果其中有错误,欢迎大家留言指正!该部分为各模式组合使用,涉及代码较多,熟能生巧。内容回顾定义适配器模式是一种结构型设计模式,...
- OOM (Out Of Memory) 故障排查指南
-
1.确认OOM类型首先需要确认是哪种类型的OOM:JavaHeapOOM:Java堆内存不足NativeMemoryOOM:本地内存不足MetaspaceOOM:元空间内存不足Contai...
- 刷完这49题,面试官当场给Offer!Java程序员必备指南
-
1.问题:如果main方法被声明为private会怎样?答案:能正常编译,但运行的时候会提示”main方法不是public的”。2.问题:Java里的传引用和传值的区别是什么?答案:传引用是指传递的是...
- C#编程基础(看这一篇就够了)_c#编程入门与应用
-
C#及其开发环境简介C#概述C#是一个现代的、通用的、面向对象的编程语言,由微软(Microsoft)开发,经Ecma和ISO核准认可。它由AndersHejlsberg和他的团队在.NET框架开发...
- 说一下JDK的监控和 线上处理的一些case
-
一句话总结JDK监控常用工具包括JConsole、VisualVM、JMC等,用于实时查看内存、线程、GC状态。线上常见问题处理:内存泄漏通过heapdump分析对象引用链;频繁GC可调整-Xmx/...
- JavaScript深拷贝极简指南:3种方法解决嵌套与循环引用难题
-
为什么需要深拷贝?首先我们看看浅拷贝,point指向的是同一个地址,这时我们修改obj2.point的属性时,obj1的point属性也会被修改再看看深拷贝,point指向的是不同地址,这时我们修改o...
- Java 25 在 JEP 519 中集成了紧凑对象头
-
作者|ANMBazlurRahman译者|刘雅梦策划|丁晓昀Java25通过JEP519将紧凑对象头作为产品特性进行了集成,在不需要更改任何代码的情况下,为开发人员提供了...
- 每日一练 Python 面试题(1)_python每日一记
-
以下是5道Python基本语法相关的面试题,涵盖变量、运算符、数据结构、函数和异常处理等核心概念:1.变量与作用域题目:以下代码的输出是什么?解释原因。x=10deffunc():...
- 一周热门
- 最近发表
-
- 半导体行业术语缩写词典总结-JKL_半导体词汇缩写表
- JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech
- Hong Kong's Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants
- http2解决了哪些问题_简述http2的优点
- China's economy stays strong and vital amid pressure
- JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire
- 深入剖析 Java 中的装饰器设计模式:原理、应用与实践
- 组合模式应用-适配器模式_适配器组件
- OOM (Out Of Memory) 故障排查指南
- 刷完这49题,面试官当场给Offer!Java程序员必备指南
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)