DNS与获取页面白屏时间

谈DNS域名解析前我们要知道我们输入 url 到页面展示的过程为浏览器获取资源和浏览器解析资源渲染页面 (回流重绘),比如当你输入 www.baidu.com 到显示百度首页过程中浏览器所做的事情。

DNS

DNS(Domain Name System,域名系统),为了请求网络资源,计算机会依赖于一种定长且具有层次结构的标识符------ip地址。例如,192.168.1.1 。我们通常输入的是网址(如www.baidu.com),然后通过DNS将其转换成对应的IP地址(因为计算器只能通过ip做请求),浏览器才能根据这个 ip 地址去请求相应的网络资源。所以DNS就是http://www.baidu.com ==> 202.xx.xx., 查询该域名对应的ip地址的过程

DNS解析过程如下图;

当在浏览器中输入www.baidu.com 进行首次请求时,也就是该域名对应的IP地址尚未被缓存,查询该域名对应的ip地址过程如下

  1. 客户端向本地域名服务器做递归查询。
  2. 本地域名服务器向根域名服务器(根 DNS 服务器)做迭代查询
  3. 本地域名服务器向顶级域名服务器(.com,.cn,.org...)做迭代查询:顶级域名服务器管理在该顶服务器域名下的二级域名(www.baidu.com,一级:.com;二级:baidu)记录了该域名的ip地址在哪里。
  4. 本地域名服务器向权限域名服务器(baidu.com,拥有确切ip地址)做迭代查询
  5. 本地域名服务器 将 ip 地址 缓存起来 (DNS 缓存)
  6. 本地域名服务器将 ip 地址 返回给客户端

最开始用的都是递归查询,太开销性能,后面除了客户端向本地域名服务器做递归查询,其它用的都是迭代查询。

然后浏览器就知道了要访问的服务器的 ip 地址了。接着依次通过 TCP 三次握手(建立连接),HTTP请求,HTTP响应,TCP 四次握手(关闭连接)。然后才获取到了资源进行回流重绘。

白屏时间的获取

白屏时间:输入 url 到页面有内容的时间。

影响白屏时间:

  1. dns 解析耗时

  2. TCP 建立连接耗时

  3. 请求耗时(CDN 网络分发,提升服务器质量,提升数据库查找效率)

  4. TCP 断开连接耗时

  5. html 结构解析耗时(减少嵌套,语义化标签的使用( header标签 )等)

  6. js 执行耗时(代码顺序,script标签放后面)

  7. css 加载耗时(CSS选择器)

  8. 图片加载耗时(懒加载)

获取白屏方法:PerformanceObserver方法

js 复制代码
// 监听首次重绘事件
const observer = new PerformanceObserver((list) => {
  const entries = list.getEntries();   // 获取浏览器执行的所有的事件
  for (let entry of entries) {
    if (entry.name === 'first-contentful-paint') {    // 首次重绘
      console.log('白屏时间: ', entry.startTime, 'ms');  // 输出白屏时间
    }
  }
})

// 监听首次重绘事件
observer.observe({ type: 'paint', buffered: true });
相关推荐
珑墨22 分钟前
前端 AI 开发通用skill
前端
kyriewen23 分钟前
一个人+Cursor,7天上线付费小程序:第1天我就想放弃了
前端·微信小程序·cursor
大家的林语冰28 分钟前
Angular 王者归来,第 22 个主版本亮相,一大波前沿技术再度引领潮流!
前端·javascript·前端框架
嵌入式ZYXC29 分钟前
第2篇:《面试题:LDO和DC-DC的区别?分别用在什么场景?》
stm32·单片机·嵌入式硬件·面试·职场和发展
小江的记录本40 分钟前
【Spring全家桶】Spring Cloud 2023.0.x:微服务核心理论、CAP/BASE定理(附《思维导图》+《面试高频考点清单》)
java·spring boot·后端·spring·spring cloud·微服务·面试
老毛肚42 分钟前
jeecgboot TS + Vue 模板化 03
前端·javascript·vue.js
下北沢美食家1 小时前
SSE 入门
前端
云计算磊哥@1 小时前
运维开发宝典023-WEB网站服务
运维·前端·运维开发
加点油。。。。1 小时前
【1.Obsidian渲染html文件】
前端·html·obsidian
ZFSS1 小时前
BYOK(自带密钥)使用指南
运维·服务器·前端·人工智能·midjourney