探究http2的多路复用实用场景

http2多路复用概念

在web.dev对http2.0的描述中,多路复用有如下特性。

将HTTP消息分解为独立的帧、交错传输,然后在另一端重新组装它们的能力是HTTP/2最重要的增强功能。事实上,它在所有web技术的整个堆栈中引入了众多性能优势的连锁反应,例如:

  • 并发多个请求,不阻塞任何一个请求。
  • 并发排列多个响应,不阻塞任何一个响应。
  • 使用单个TCP连接可以并行传递多个请求和响应。.
  • 删除不必要的HTTP/1.x解决方案(请参阅优化HTTP/1.x,如级联文件、图像精灵和域碎片)。
  • 通过消除不必要的延迟和提高可用网络容量的利用率,降低页面加载时间。.

其实总的来说,就是使用帧(frame)进行数据传输,使得同一个域下的所有请求,可以在一个TCP连接中进行传递,最高效率的利用信道负载。

http2多路复用实际场景分析

下面构造一些实际场景,对比http1.1和http2.0的效果:

1. 请求堵塞

先用nginx模拟一个要等待10s的请求,longTask:

实际情况下,这种服务端耗时大的请求常常是主要的页面的性能瓶颈之一。

那么运行以下代码:

js 复制代码
for(let i = 0; i < 100; i++) {
    fetch(`https://localhost:8094/longTask${i}`)
}

http1.1效果:

http2效果:

这对比效果就很明显了,http1.1因为同一个域下只有6条TCP链接上限,故100个堵塞请求并发,后面的请求需要等前面的请求都完成才能触发。可以看到,等待时间已经达到2.7min。

而http2可以将请求并发(看起来也不是能直接并发所有请求,最后一个请求有2s的延迟,可能和信道的传输上限有关)。直接避免了因为堵塞的请求造成的网络性能问题。

2. 大量请求或者文件下载

使用一个加载时间大约9s的视频资源作为测试

运行下列代码:

js 复制代码
for(let i = 0; i < 1000; i++) {
    fetch("https://localhost:8096/video/1.mp4")
}

http1.1效果:

http2效果:

在这个案例中,http1.1和http2所花时间耗时基本相同。因为下载视频的时间都是处于content download阶段,是一直需要信道资源的,所以虽然http2可以使用分帧传输,但是在信道资源被占满的情况下,后续的请求也只有进行等待了。

在上一个案例中,等待的阶段是waiting for serve response 这个时候虽然有100并发,但是信道基本是空载的,没有信息帧传输,所以才能达到100请求同时完成的效果。

总结

综上所述,http2.0的多路复用虽然能解决类似请求堵塞造成的性能问题,但是前端依然需要在方案层面严格控制请求并发,大量的请求仍然会对实际生产场景产生堵塞问题。

相关推荐
cfm_29142 小时前
Redis缓存规范设计与全方位性能优化实战
redis·缓存·性能优化
ct9787 小时前
Three.js 性能优化(测量-定位-优化)
javascript·性能优化·three
爱喝水的鱼丶12 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第五篇:SAP 报表多格式输出:Excel/PDF 批量导出功能实现
学习·性能优化·pdf·excel·sap·abap
unicrom_深圳市由你创科技12 小时前
一套仓库管理多站点:性能优化与搜索友好全链路指南
性能优化
战南诚13 小时前
HTTP 与 HTTPS 的区别:从原理到实战详解
网络协议·http·https
千里马学框架15 小时前
深入剖析安卓布局uiautomator抓取工具原理
android·智能手机·性能优化·perfetto·view·安卓framework开发·布局抓取
风停了,叶落了15 小时前
2026年5月28日笔记
http
mCell15 小时前
别急着骂运营商,你家路由器里可能藏着一台 PCDN 盒子
前端·http·cdn
SilentSamsara17 小时前
文件与数据处理:CSV/JSON/Excel/Parquet 高效操作与内存优化
开发语言·python·青少年编程·性能优化·json·excel
Seven9717 小时前
别只会说 HTTPS 更安全:一文吃透加密、证书与 TLS 握手
tcp/ip·http