说到 HTTP
的 103
状态码,你可能很早就听说过了,但是你不一定真的理解了它。
这很正常,这个状态码早在 2017
年就被提出来了,但是支持它的服务器和浏览器真的很少。
直到前几天,Chrome
宣布在 Chrome 103
版本对 HTTP 103
状态码提供了支持,不得不说老外还挺皮啊...
今天我们就来看一下,HTTP 103
状态码究竟有什么用途。
随着时间的推移,网站变得越来越复杂。一些大型网站的服务器可能需要执行很多重要的工作(例如,访问数据库或访问源服务器的 CDN
)来为请求的页面生成 HTML
。
但是,这种 服务器的思考时间
会在浏览器开始渲染页面之前带来额外的延迟。因为浏览器需要先把 HTML
页面加载回来,才能知道下一步去加载哪些 JavaScript、CSS
或字体文件等。中间这段时间实际上就浪费掉了,对用户访问我们的页面来讲,这段等待时间就是白屏或是不可用的状态。
我们来看看抖音 Web
站的资源加载:浏览器先要等待前面两个 HTML
的大约 800 ms
的时间才能去加载后面的 JS 、CSS
等资源文件。
有没有办法在等待 HTML
响应的同时就去提前把重要的静态资源文件也加载回来呢?
HTTP 103
状态码 (Early Hints
) 是一个信息性 HTTP
状态代码,可以用于在最终响应之前发送一个初步的 HTTP
响应。
利用 HTTP 103
状态码,就可以让服务器在服务器处理主资源的同时向浏览器发送一些关键子资源(JavaScript、CSS
或字体文件)或页面可能使用的其他来源的提示。
浏览器可以使用这些提示来预热连接,并在等待主资源响应的同时请求子资源。换句话说,Early Hints
可以通过提前做一些工作来帮助浏览器利用这种 服务器思考时间
,从而提升页面的渲染性能。
在某些情况下,这可以帮助 LCP
(最大内容绘制)至少提升几百毫秒。例如在 Shopify
和 Cloudflare
所观察到的来看,LCP
大概提升了 1 秒。
启用 Early Hints 前后对比
在开始使用之前,可能要先思考下,什么样的网站比较适合这个优化。
如果你的网站的主页面响应非常快,可能没什么必要。比如对于大部分 SPA
(单页应用),可能用处不是那么大。
在 SPA
中,大部分的逻辑都在客户端,HTML
很小,下发 HTML
的服务器也基本就是没有什么逻辑的静态服务器。大部分情况下只会包括一个 Root
节点,以及一些资源的 Link
,大部分逻辑和加载时间其实都在打包后的 JavaScript
中。这种情况我们只需要使用常规的 rel=preload、rel=preconnect
等手段就可以了。
但是在SSR
项目中,加载 HTML
往往需要在服务端花费更多的时间,因为服务端可能和数据库交互以及将数据拼接成 HTML
元素。相比之下,加载其他的脚本和样式资源可能花费的时间要更短一点,这种站点启用 Early Hints
是比较合适的。
在 Chrome 103
版本,对 HTTP 103
状态码 (Early Hints
) 提供了支持。
启用 Early Hints
的第一步就是要确认我们站点的 主页面
,也就是用户通常在访问我们的网站时开始的页面。如果我们有很多来自其他网站的用户,主页面
可能就是主页或热门的产品列表页面。
Early Hints
的用途会随着用户在我们的站内导航的次数而降低,因为浏览器可能已经在前几次导航中把所有需要的子资源请求回来了,给用户良好的第一印象是最重要的!
确认了站点的 主页面
,下一步就是确定哪些来源或子资源将是最佳预连接或预加载的候选者。通常情况家,我们要找的就是对关键用户指标(LCP
或 FP
)贡献最大的源和子资源。具体一点,就是找到阻塞渲染的子资源,例如同步 JavaScript
、样式表,甚至网络字体等。
然后就是尽量避免选择已经过时或者不再被主页面使用的资源。
比如一些经常更新或者带有 hash
的资源(conardli.top/static/home.aaaa1.js
),尽量不要选择,这可能会导致页面需要加载的资源和实际预加载的资源不匹配。
比如我们举个例子:
首先我们去服务器请求主页面:
GET /home.html
Host: conardli.top
User-Agent: [....] Chrome/103.0.0.0 [...]
服务器预测站点将需要 home.aaaa1.js
,并建议通过 Early Hints
预加载它:
103 Early Hints
Link: </home.aaaa1.js>; rel=preload; as=script
[...]
随后,客户端马上向服务端请求了 home.aaaa1.js
。然而,这时 JS
资源更新了,主页面已经需要另外一个版本的 JS
了。
200 OK
[...]
<HTML>
<head>
<title>Conardli's Blog</title>
<link rel="script" href="/home.aaaa2.js">
所以,我们最好选择一些比较稳定的资源进行预加载,我们可以对 JS 进行拆包,将不经常发生变化的稳定部分和经常发生更新的动态脚本部分拆成多个资源。我们只对稳定部分实施预加载,在浏览器获取到主页面后再去加载动态部分。
<HTML>
<head>
<title>code秘密花园</title>
<link rel="script" href="/home.js">
<link rel="script" href="/home.aaaa1.js">
最后,在服务器端,查找已知支持 Early Hints
的浏览器发送的主页面请求,并响应 103 Early Hints
。在 103
响应中,会包括相关的预连接和预加载提示。主页面准备好后,再按照正常的响应进行响应。为了向后兼容,最好在最终响应中包含 LINK HTTP
标头,甚至也可以增加在生成主页面时需要的一些明显的关键资源。
Early Hints
响应:
GET /main.html
Host: conardli.top
User-Agent: [....] Chrome/103.0.0.0 [...]
103 Early Hints
Link: <https://fonts.google.com>; rel=preconnect
Link: </main.css>; rel=preload; as=style
Link: </common.js>; rel=preload; as=script
成功响应:
200 OK
Content-Length: 7531
Content-Type: text/html; charset=UTF-8
Content-encoding: br
Link: <https://fonts.google.com>; rel=preconnect
Link: </main.css>; rel=preload; as=style
Link: </common.js>; rel=preload; as=script
Link: </experimental.3eab3290.css>; rel=preload; as=style
<HTML>
<head>
<title>code秘密花园</title>
<link rel="stylesheet" href="/main.css">
<link rel="stylesheet" href="/home.aaaa1.css">
<script src="/common.js"></script>
<link rel="preconnect" href="https://fonts.googleapis.com">
看到这里你可能发现了,这玩意和 HTTP2
的服务器推送 (Server Push
) 很像啊。
Server Push
即在浏览响应 HTML
文件的时候,服务器会同时将所需的资源文件主动推送给浏览器。
浏览器在收到推送的资源之后会缓存到本地。等解析 HTML
发现需要加载对应资源的时候会直接从本地读取,不必再等待网络传输了。
虽然这听起来很神奇,但这个方案有非常大的缺陷:Server Push
很难避免推送浏览器已经拥有的子资源,其实很多资源在浏览器第一次请求到就已经缓存下来了。这种 “过度推动” 会导致网络带宽的使用效率降低,从而显着阻碍性能优势。总体而言,Chrome
数据显示 HTTP2/Push
实际上对整个网络的性能产生了负面影响。
所以,Chrome
宣布移除了对 HTTP/2 Server Push
特性的支持:
相比之下,Early Hints
在实践中表现更好,因为它结合了发送初步响应的能力和提示,浏览器实际上只负责获取它实际需要的资源。虽然 Early Hints
还没有涵盖 HTTP/2 Server Push
理论上可以解决的所有用例,但是它解决了网络带宽浪费的问题,可以说是 HTTP/2 Server Push
的升级版。
浏览器支持情况:
服务器支持情况:
Node.js
:通过 Fastify
插件提供支持;Apache
:通过 mod_http2
支持;H2O
:支持;Nginx
:实验模块。参考链接:
本文由哈喽比特于2年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/GjvUqmok8f1efWPkSzkr1w
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。