在线咨询
技术分享

浅析如何减少域名DNS解析时间将网页加载速度提

微易网络
2026年2月10日 16:40
190 次阅读

提高网页的打开速度,一般地我们会选择使用CDN,利用就近原则让用户在最短的时间内获取到服务器资源,实际应用当中采用CDN的方式提高网站访问速度的效果也是最明显的。这也就是

减少域名DNS解析时间将网页加载速度提升新层次-DNS缓存/预读取/拆分域名

 

提高网页的打开速度,一般地我们会选择使用CDN,利用“就近原则”让用户在最短的时间内获取到服务器资源,实际应用当中采用CDN的方式提高网站访问速度的效果也是最明显的。这也就是为什么国外的空间打开速度远不及国内的主机的访问速度的原因了。

 

我们知道在用户访问网站时先得经过域名DNS解析这一过程,可能很多人对于DNS解析时间平常并没有太在意。性能稳定、响应时间快的DNS域名解析服务与不稳定、响应过慢的DNS的域名解析时间可能相差1秒,而对于网站存在过多的域名解析请求,这个时间积累起来就非常地多了。

 

本篇文章就来分享一下通过优化网站DNS域名解析,减少域名DNS解析时间,从而让网站在原来的访问速度的前提下继续实现新的飞跃。

 

减少域名DNS解析时间将网页加载速度提升到新层次-DNS缓存/预加载/多域名

 

一、域名DNS解析原理和过程

 

1、DNS是怎么来的?DNS 是域名系统 (Domain Name System) 的缩写。在Internet上域名与IP地址之间是一对一(或者多对一)的,域名虽然便于人们记忆,但机器之间只能互相认识IP地址,它们之间的转换工作称为域名解析,域名解析需要由专门的域名解析服务器来完成,DNS就是进行域名解析的服务器。

 

2、DNS解析的基本过程一:查找本地域名DNS缓存。当用户通过浏览器访问某域名时,浏览器首先会在自己的缓存中查找是否有该域名对应的IP地址,例如计算机系统Hosts文件域名对应IP、路由器缓存、ISP(互联网服务提供商)DNS缓存。

 

域名DNS解析的原理

 

3、DNS解析的基本过程二:通过上面的DNS查询依然没有找到想你的域名对应的IP地址,那么就要进入根服务器进行查询。全球共有13台根逻辑域名服务器。这13台逻辑根域名服务器中名字分别为“A”至“M”,真实的根服务器在2014年1月25日的数据为386台,分布于全球各大洲。

 

4、在根域名服务器中虽然没有每个域名的具体信息,但储存了负责每个域(如COM、NET、ORG等)的解析的域名服务器的地址信息。根域名服务器会将其管辖范围内顶级域名(如.com)服务器IP告诉本地DNS服务器,这样你的域名查询请求会进入到相应的顶级域名服务器。

 

5、DNS解析的基本过程三:顶级域名服务器收到请求后查看区域文件记录,若无则将其管辖范围内主域名(不带任何前缀的域名,如freehao123.com)服务器的IP地址告诉本地DNS服务器。如果还是没有找到,则进入到下一级域名服务器进行查找。如此重复,直到找到正确的结果为止。

 

6、查找到正确的域名对应IP地址后,本地域名服务器把返回的结果保存到缓存,以备下一次使用,同时将该结果反馈给客户端,客户端通过这个IP地址与web服务器建立链接。于是你的浏览器就正常访问网站了。下图是对Google.com为例,解释用户在访问谷歌时DNS解析的全过程。(点击放大)

 

域名DNS解析全过程

 

二、浏览器加载网页的基本过程

 

1、从浏览器地址栏的请求链接开始,浏览器通过DNS解析查到域名映射的IP地址,成功之后浏览器端向此IP地址取得连接,成功连接之后,浏览器端将请求头信息通过HTTP协议向此IP地址所在服务器发起请求,服务器接受到请求之后等待处理。

 

域名解析的时间

 

2、览器加载显示html的顺序是:从上到下,渲染的顺序也是从上到下,下载和渲染是同时进行的。如果遇到语义解释性的标签嵌入文件(JS脚本,CSS 下载过程会启用单独连接进行下载,并且在下载后进行解析,解析过程中,停止页面所有往下元素的下载。(点击放大)

 

浏览器加载网页的时间线

 

3、什么原因会导致网页加载过慢?浏览器可以在下载CSS资源的同时,并行解析HTML文件,但是,一旦发现有脚本文件的引用,则必须等待脚本文件完成下载并且执行后才能继续解析。内容下载时间主要取决于用户带宽、服务器带宽、文件大小、文件数量等。

 

三、合理利用DNS TTL值 增加域名的缓存命中率

 

1、DNS 服务器采用递归或迭代来处理客户端查询时,它们将发现并获得大量有关 DNS 命名空间的重要信息。然后这些信息由服务器缓存。缓存为 DNS 解析流行名称的后续查询提供了加速性能的方法,同时大大减少了网络上与 DNS 相关的查询通信量。

 

合理利用DNS TTL值

 

2、TTL(Time-To-Live)即一条域名解析记录在DNS服务器上缓存时间。当信息缓存时,生存时间 (TTL) 值适用于所有缓存的 RR。只要缓存 RR 的 TTL 没有到期,DNS 服务器就可继续缓存并再次使用 RR 来应答与这些 RR 相匹配的客户端提出的查询。

 

提高域名DNS服务器缓存时间

 

3、适当地增大TTL值可以让DNS Server缓存该域名更长时间,增加缓存的命中率。TTL一般默认为一小时,可以根据实际情况设为一天甚至一周以上。当然,如果你域名的IP经常变化,则TTL不应过大,否则各地的DNS Server会暂时无法获得新的正确的IP地址。

 

四、合理使用DNS-prefetch让DNS预读取

 

1、从上面浏览器加载网页的过程可以看出,网页的请求是可以多任务同时进行的,对于网页有多个DNS请求的情况,可以让浏览器在后台先把要使用的DNS请求默默地完成,这样当用户在打开新的网页时,就可以节省DNS查询的时间了。

 

使用DNS预读取加快网页打开速度

 

2、控制浏览器的DNS预读取就是DNS-prefetch标签了,DNS Prefetch应该尽量的放在网页的前面,格式类似是:

 

很多网站都使用使用百度广告联盟代码,使用这个就可以预读取DNS了。

 

3、默认情况下浏览器会有隐式的DNS Prefetch,即会对页面中和当前域名(正在浏览网页的域名)不在同一个域的域名进行预获取,并且缓存结果,我们可以通过下面的标签禁止隐式的DNS Prefetch:

 

4、需要注意的就是,DNS Prefetch只需要在用户在第一次打开网站时使用即可,没有必要每个页面都使用DNS Prefetch,否则就是重复DNS读取了,反而还无形中增加了DNS查询的次数,效果适得其反。

 

五、DNS域名解析拆分为多个域名增加并行下载量

 

1、一般来说网页的内容加载时会发生多个域名请求服务,如果你的网站JS、CSS、图片等非常多的话,建议将这些文件分别放在不同的域名上,这样浏览器在打开某一个页面时就可以同时向这些域名发送DNS解析请求了,能在一定程度上减少DNS时间。(点击放大)

 

DNS域名解析拆分为多个域名

 

2、网页的内容越多,分析的域名应该尽量多一些。例如html、htm,js、css,jpg、png、gif,php、asp都可以放在不同的域名上。在实际应用上,使用全站CDN或者是静态文件CDN就可以实现上述效果,并且结合css sprite一起来使用的。

 

减少网页的DNS请求次数

 

3、css sprite的作用恰恰相反,它不是增加域名请求,而减少域名DNS请求,主要是用在图片上。它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就不会像以前那样一幅一幅地慢慢显示出来了。

 

六、加快域名DNS解析速度方法小结

 

1、本文介绍的用DNS缓存、DNS预读取、拆分域名来减少域名DNS解析的时间的方法,对于一般的网站的加速效果可能并不明显,但是对于一些每天DNS请求达到上百万级以上的网站,DNS加速的效果就显而易见了。另外,如果发现自己的网站响应速度过慢,不妨好好检查一下网页的DNS用时。

 

2、除了从网站本身的DNS解析来加快访问速度外,我们平常在选择DNS服务时尽量使用那些稳定可靠的DNS服务,这样的DNS服务响应速度和缓存率都是非常不错的。假如自己的网站分拆了多个二级域名,不妨好好用用CNAME,设置好TTL时间,保证网站的第一次解析,可以直接从运营商的DNS缓存中拿到。

微易网络

技术作者

2015年3月17日
190 次阅读

文章分类

技术分享

需要技术支持?

专业团队为您提供一站式软件开发服务

相关推荐

您可能还对这些文章感兴趣

技术人员职业发展规划:技术成长心路历程
技术分享

技术人员职业发展规划:技术成长心路历程

这篇文章讲的是一位技术老手分享自己从“写代码的”到“做架构”的成长心路历程。文章用真实案例,比如防伪溯源平台用户量暴增后系统卡死的经历,点出技术人常见的焦虑:怎么学技术不掉队,怎么从单纯写代码变成能独当一面的骨干。读起来就像朋友聊天,特别适合那些感觉每天忙但没沉淀的技术朋友。

2026/6/15
人才培养方法:技术成长心路历程
技术分享

人才培养方法:技术成长心路历程

这篇文章讲了技术人才培养的那些真实经历,用防伪溯源行业的实战案例,分享了怎么把技术小白带成排查高手。文章特别强调,新人成长不是一上来就写代码,而是先“看”——看项目代码、看生产日志、看别人怎么解决问题。没有空话套话,全是踩过的坑和管用的方法,适合所有带新人团队的老板和负责人看看。

2026/6/15
命令行工具:团队协作经验分享
技术分享

命令行工具:团队协作经验分享

这篇文章讲了作者团队用命令行工具解决协作难题的真实经历。文章分享了他们从代码冲突不断、环境配置混乱,到靠几个命令行工具让效率提升30%以上的转变过程。说白了,就是用“团队默契”代替“个人英雄”,用统一工具搞定日常协作中的那些烦心事。如果您也头疼团队开发效率问题,这篇经验分享特别值得一看。

2026/6/15
性能优化经验:实战经验总结
技术分享

性能优化经验:实战经验总结

这篇文章讲的是性能优化的实战经验,作者用自己给电商平台做优化的例子,生动分享了从排查问题到解决问题的过程。重点推荐了Lighthouse和WebPageTest这两个免费又好用的浏览器插件,把它们比作性能优化的“侦察兵”。整体风格很接地气,就像老司机在跟你掏心窝子聊踩过的坑,全是干货,不整虚的。

2026/6/15

需要专业的软件开发服务?

郑州微易网络科技有限公司,15+年开发经验,为您提供专业的小程序开发、网站建设、软件定制服务

技术支持:186-8889-0335 | 邮箱:hicpu@me.com