很多人都知道现代浏览器都支持 DNS 的预解析,学名:DNS Prefetching。用法也很简单,就是在html代码里加入这样的 link 标签
<link rel="dns-prefetch" href="//delai.me">
我们之前的用法是在 Head 为2个 静态资源服务器的域名 和 日志图片的域名 建了3条 dns-prefetch link。
<link rel="dns-prefetch" href="//tj.koudaitong.com/" />
<link rel="dns-prefetch" href="//imgqn.koudaitong.com/" />
<link rel="dns-prefetch" href="//kdt-static.qiniudn.com/" />
我最近给移动web 关键静态资源做 File Prefetching,顺手看了下Chromium 和 Firefox 关于 DNS Prefetching 的官方文档 看到这么一句:
Manual PrefetchChromium uses the "href" attribute of hyperlinks to find host names to prefetch. However, some of those hyperlinks may be redirects, for example if the site is trying to count how many times the link is clicked. In those situations, the "true" targeted domain is not necessarily discernible by examining the content of a web page, and so Chromium not able to prefetch the final targeted domain.
上面这段文字包含两个信息:
我写了一个测试页面,代码是这样的:
<html>
<head></head>
<body>
<a href="http://a.youzan.com">a.youzan.com</a>
<a href="http://b.youzan.com">b.youzan.com</a>
<a href="http://c.youzan.com">c.youzan.com</a>
<a href="http://d.youzan.com">d.youzan.com</a>
</body>
</html>
在chrome里打开他,然后访问 chrome://histograms/DNS.PrefetchQueue ,看到如下统计结果 当然,上图并不能说明什么问题,只能看出:从启动chrome到访问刚刚这个测试页面,一共有88次dns prefetching,其中67次直接命中耗时0ms,有4词耗时5ms。不过,如果把测试页面改成下面这个样子再跑一次就有点意思了:
<html>
<head></head>
<body>
<a href="http://a.youzan.com">a.youzan.com</a>
<a href="http://b.youzan.com">b.youzan.com</a>
<a href="http://c.youzan.com">c.youzan.com</a>
<a href="http://d.youzan.com">d.youzan.com</a>
<a href="http://a1.youzan.com">a1.youzan.com</a>
<a href="http://b1.youzan.com">b1.youzan.com</a>
<a href="http://c1.youzan.com">c1.youzan.com</a>
<a href="http://d1.youzan.com">d1.youzan.com</a>
<a href="http://a2.youzan.com">a2.youzan.com</a>
<a href="http://b2.youzan.com">b2.youzan.com</a>
<a href="http://c2.youzan.com">c2.youzan.com</a>
<a href="http://d2.youzan.com">d2.youzan.com</a>
<a href="http://a3.youzan.com">a3.youzan.com</a>
<a href="http://b3.youzan.com">b3.youzan.com</a>
<a href="http://c3.youzan.com">c3.youzan.com</a>
<a href="http://d3.youzan.com">d3.youzan.com</a>
<a href="http://a4.youzan.com">a4.youzan.com</a>
<a href="http://b4.youzan.com">b4.youzan.com</a>
<a href="http://c4.youzan.com">c4.youzan.com</a>
<a href="http://d4.youzan.com">d4.youzan.com</a>
</body>
</html>
统计结果变成了: 可以看出:因为页面里有20个a标签带href属性,chrome做了20次dns prefetching,其中耗时为0的次数比之前加了4,那是因为头4个域名在上一次跑测试页面的时候已经被prefetch过了本地已经有记录,直接命中。其余的16个dns prefetching 耗时基本上离散分布不甚相同。
实际情况如文档所说,我的理解也是对,我们之前的使用姿势有点问题。
1.对静态资源域名做手动dns prefetching。
2.对js里会发起的跳转、请求做手动dns prefetching。
3.不用对超链接做手动dns prefetching,因为chrome会自动做dns prefetching。
4.对重定向跳转的新域名做手动dns prefetching,比如:页面上有个A域名的链接,但访问A会重定向到B域名的链接,这么在当前页对B域名做手动dns prefetching是有意义的。
1.假设页面Head里面有个css链接, 在当前页的Head里加上对应的手动dns prefetching的link标签,实际上并没有好处。
2.普遍来说合理的dns prefetching能对页面性能带来50ms ~ 300ms的提升,有人做了这方面的统计。
3.如chromium的官方文档所说,dns prefetching的网络消耗是极低极低的:
Each request typically involves sending a single UDP packet that is under 100 bytes out, and getting back a response that is around 100 bytes. This minimal impact on network usage is compensated by a significant improvement in user experience.
4.如chromium的官方文档所说,chrome使用8个线程专门做dns prefetching 而且chrome本身不做dns记录的cache,是直接从操作系统读dns —— 也就是说,直接修改系统的dns记录或者host是可以直接影响chrome的。
5.手动dns prefetching的代码实际上还是会增加html的代码量的,特别是域名多的情况下。
所以,最优的方案应该是:通过js初始化一个iframe异步加载一个页面,而这个页面里包含本站所有的需要手动dns prefetching的域名。事实上,我们已经这么多了,稍后会再发一篇博文详细介绍。
本文也发布于我的 个人技术博客:http://delai.me/code/dns-prefetching/
欢迎关注我们的公众号
Original url: Access
Created at: 2019-09-26 16:41:34
Category: default
Tags: none
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论