从浏览器地址栏输入URL到展示页面经历了什么?

本文主要写url到页面的具体过程,以及涉及一点浏览器渲染过程。

过程
  1. DNS解析
    • 浏览器的DNS缓存(硬盘或SSD)
    • 系统的DNS缓存
    • 路由器的DNS缓存
    • 网络运营商的DNS缓存(中国移动,中国电信)
    • 上述都没有找到,则会采取递归的方式,向根服务器进行查询,根服务器告诉本地DNS服务器域服务器的地址,本地DNS向域服务器发出请求,域服务器告诉本地服务器域名解构服务器的地址,本地服务器向域名解构服务器发出请求,收到域名和IP的关系,本地服务器再返回给浏览器并将对应关系保存在缓存中以便下一次使用。下图是他递归的过程。
      在这里插入图片描述
      DNS优化
    • DNS缓存
      DNS存在着多级缓存,从离浏览器的距离排序的话,有以下几种: 浏览器缓存,系统缓存,路由器缓存,IPS服务器缓存,根域名服务器缓存,顶级域名服务器缓存,主域名服务器缓存。
    • DNS负载均衡
      DNS可以返回一个合适的机器的IP给用户,例如可以根据每台机器的负载量,该机器离用户地理位置的距离等等,DNS可以返回一个合适的机器的IP给用户,例如可以根据每台机器的负载量,该机器离用户地理位置的距离等等,

注意:?
域名:一台或者一组服务器的名称,用来确定服务器在internet上的位置
url:统一资源定位符,用来确定某一文件的具体位置
IP和域名是对应关系吗???答案是不是,可以把多个提供相同服务的服务器IP设置为同一个域名,同时,一个IP可以绑定多个域名,数量不限。

  1. 当浏览器拿到IP后,就向服务器发送http连接请求,三次握手。

  2. 发送请求

  3. 接受响应
    服务器解析浏览器请求的url,找到目标资源文件,将资源文件发送给客户端

  4. 浏览器解析资源,并请求html中链接的其他资源文件(js和css阻塞问题),最后进行页面渲染

    • 处理HTML标记并构建DOM树;
    • 处理CSS标记并构建CSSDOM树;
    • 将DOM和CSSOM合并为一颗渲染树;
    • 根据渲染树来布局,以计算每个节点的几何信息;(重排)
    • 将各个结点绘制到屏幕上。(重绘)
    • 如果 DOM 或 CSSOM 被修改,以上过程需要重复执行,这样才能计算出哪些像素需要在屏幕上进行重新渲染(重绘和重排)
  5. 断开连接 “TCP四次挥手”

    浏览器采用的是流式布局,也就是某一个dom节点更新了,就需要对DOM结构进行重新计算,重新布局界面,再次引发回流(重排)。
    重排:一个元素发生改变,会引起局部或者是全局DOM都改变。
    引起重排的原因:页面首次渲染,浏览器窗口大小发生改变,元素尺寸,位置,内容,字体大小等都会引起重排
    重绘:不改变元素的位置

当用户在浏览器地址栏输入内容并按下回车键时,浏览器经历以下步骤来打开网页: 1. 解析URL浏览器会解析用户输入URL(统一资源定位符),URL包含了要访问的网页的地址和其他参数。 2. DNS解析:浏览器会向域名系统(DNS)服务器发送一个请求,以获取输入URL中所包含的网址的IP地址。DNS服务器将返回对应的IP地址,使得浏览器能够与服务器建立连接。 3. 建立连接:浏览器使用HTTP或HTTPS协议与服务器建立连接。对于HTTPS协议,还会进行SSL/TLS握手过程来建立安全连接。 4. 发送请求:浏览器会向服务器发送一个HTTP请求,其中包含了用户请求的网页和其他相关信息,如请求方法(GET、POST等)和请求头部(包含浏览器的信息、支持的数据格式等)。 5. 服务器处理请求:服务器接收到浏览器发送的请求后,会根据请求的内容进行处理。这可能包括读取数据库、执行动态代码等操作。 6. 响应生成:服务器处理完成后,会生成一个HTTP响应。响应中包含了网页的内容、状态码(表示请求成功或失败的数字代码)和其他相关信息。 7. 接收响应:浏览器接收到服务器发送的HTTP响应后,会开始解析响应。浏览器会根据响应头部的信息来判断如何处理响应内容。 8. 渲染页面:如果响应中的状态码表示成功(例如200),浏览器会开始渲染页面。它会解析HTML、CSS和JavaScript代码,构建DOM树和渲染树,并将网页内容显示浏览器窗口中。 9. 下载资源:在渲染页面的过程中,浏览器可能会发现页面中引用了其他资源,如图像、样式表、脚本文件等。浏览器会发送请求来下载这些资源,并将其添加到页面中。 10. 执行脚本:如果页面包含了JavaScript代码,浏览器会执行这些脚本,以实现交互和动态效果。 11. 网页加载完成:当所有的资源都被下载并且页面完成渲染时,浏览器会触发页面加载完成的事件。 这是一个简要的描述,实际上,浏览器的工作过程还涉及到缓存机制、安全策略、优化算法等。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值