首页 > 其他分享 >前端性能----从输入URL开始到返回数据的中间经历过程

前端性能----从输入URL开始到返回数据的中间经历过程

时间:2022-12-20 22:03:10浏览次数:66  
标签:浏览器 URL 前端 TCP 查询 ---- DNS 服务器 路由

这是一个古老的问题,即我们输入URL后按下回车到网页测呈现都发生了什么?

加载过程到显示如下:

  • 1.根据域名,进行DNS域名解析;
  • 2.拿到解析的IP地址,建立TCP连接;
  • 3.向IP地址,发送HTTP请求;
  • 4.服务器处理请求;
  • 5.返回响应结果;
  • 6.关闭TCP连接;
  • 7.浏览器解析HTML;
  • 8.浏览器布局渲染;

首先来看一张图: 

  

前端性能----从输入URL开始到返回数据的中间经历过程_DNS

 

 

 

表示了数据从源端到目的端的封装和拆解过程

 

预处理URL

URL格式: ​​​

以http为例:

http://www.example.com:80/path/to/myfile.html?key1=value1&key2=value2#SomewhereInTheDocument

 有时候我们并没有输入完整的url,浏览器会智能地进行自动补全,如浏览器会对不同协议自动添加端口,如http的80端口,https的443端口等等。除此之外浏览器还会根据我们的历史记录,书签等信息进行智能提示,并对一些非ASCII字符进行编码。如果不合法,将会转为搜索关键字。 

 

DNS解析

  浏览器在得到合法的URL后,就要进行域名解析,DNS采用UDP协议进行传输数据,默认端口为53,DNS查询过程本质上还是一个客户端请求服务端的过程,它同样会经过其下面的网络层和数据链路/物理层的封装。

只考虑查询过程:

  • 从浏览器自身DNS缓存中查找结果,上一章中我们提到了DNS预解析优化策略就是提前进行DNS解析放入缓存(要查看 Chrome 当中的缓存, 打开 ​​chrome://net-internals/#dns​​)
  • 在操作系统DNS缓存中查询,如linux上的​​NSCD​​缓存服务
  • 读取hosts文件,如*nix上的​​/etc/hosts​
  • 查询配置的DNS服务器查询
  • 递归查询过程: 本地DNS服务器查询自己的缓存记录(本地DNS服务器一般都是你的网络接入服务器商提供,比如中国电信,中国移动),如果有则返回,如果没有则去查询根DNS服务器。
  • 迭代查询过程: 根DNS服务器告诉本地DNS服务器顶级域的DNS地址,本地DNS再查询通过顶级域DNS找到下一级域的DNS地址,以此迭代查询直到找到域名和IP的对应信息
  • 找到关系后,本地DNS返回结果给客户机,并进行相应的缓存

       

前端性能----从输入URL开始到返回数据的中间经历过程_IP_02

 

 

   

前端性能----从输入URL开始到返回数据的中间经历过程_服务器_03

 

  图片来源:51cto

  我们可以使用命令​​dig +trace www.luoxia.me​​来跟踪dns查询过程:

  

前端性能----从输入URL开始到返回数据的中间经历过程_DNS_04

 

 

 

可以清晰地看到这个迭代查询的过程。

Socket发送数据

浏览器得到IP地址和端口号以后,就会调用系统库函数​​socket​​,请求一个TCP流套接字,下面是之后的逐层封装过程:

  • 这个请求首先被交给传输层,在传输层请求被封装成 TCP segment。目标端口会被加入头部,源端口会在系统内核的动态端口范围内选取(Linux下是ip_local_port_range)
  • TCP segment 被送往网络层,网络层会在其中再加入一个 IP 头部,里面包含了目标服务器的IP地址以及本机的IP地址,把它封装成一个TCP packet。
  • 这个 TCP packet 接下来会进入链路层,链路层会在封包中加入 frame 头部,里面包含了本地内置网卡的MAC地址以及网关(本地路由器)的 MAC 地址。如果内核不知道网关的 MAC 地址,它必须进行 ​​ARP​​ 广播来查询其地址。

 

数据传输

数据可以通过以下方式进行传输:

  • 以太网
  • WiFi
  • 蜂窝移动网络 

 

  数据经过一层层封装,经过本地网络,传送到网络的下一个节点,再到管理该主机所在子网的路由器,这个路由器经过区域内路由(Intra-AS routing)算法(如RIP)将数据发送给​​自治区域​​(autonomous system, 缩写 AS,如运营商区域网络)的边界路由(网关),再通过区域间路由(Inter-AS routing)算法(如BGP)找到其他域的边界路由,再经过区域内路由算法,直到找到目的主机。

  一路上经过的这些路由器会从IP数据报头部里提取出目标地址,并将封包正确地路由到下一个目的地。IP数据报头部 ​​time to live (TTL)​​ 域的值每经过一个路由器就减1,如果封包的TTL变为0,或者路由器由于网络拥堵等原因封包队列满了,那么这个包会被路由器丢弃。

  此外,由于IPV4的能够分配的IP有限,我们往往使用​​NAT​​来进行公网到内网的地址映射:

  

前端性能----从输入URL开始到返回数据的中间经历过程_IP_05

 

 

 

数据包最终传到目的主机的网卡,接着网卡会将数据拷贝到内存中(DMA),然后通过中断来通知 CPU,经过一层层的拆解到达指定端口的进程进行处理。

可以看到,我们的数据包会经过多个路由的不断转发,由于路由存在的各种延迟,会导致性能瓶颈的出现,后面会细讲。此外,TCP协议用于点对点的可靠传输,此部分也存在性能瓶颈,会在后面的小节单独展开。

可以通过命令​​traceroute​​查看数据包经过的路由.

HTTP协议

客户端发起的请求形成HTTP请求报文,经过层层封装最终到达服务端HTTP服务器所在进程,HTTP服务在接受到请求报文后,连同数据形成响应报文,再通过传输层、网络层等等地包装传输回客户端。

以​​luoxia.me/images/climb.jpg​​为例:

   

前端性能----从输入URL开始到返回数据的中间经历过程_服务器_06

 

 

 

访问网页的时候,服务端最终返回html文档,接下来就是网页的渲染过程了,这部分参照​​网页渲染原理章节​​。

各层协议的具体字段可以通过抓包分析

 

从输入url到数据内容的返回,更多的学习:


        ​​http://www.bubuko.com/infodetail-2275283.html​

 

参考:

 

 

  

 作者:Syw



标签:浏览器,URL,前端,TCP,查询,----,DNS,服务器,路由
From: https://blog.51cto.com/u_15739244/5956849

相关文章

  • 构建自动化测试体系的考虑因素
    自动化体系的建设初期面临的问题无法使用目前市面上的开源自动化测试工具。因为这部分的工具大多基于桌面客户端,弊端明显,缺乏系统性的过程管理,无法适应公司级别的自动化体系......
  • 性能测试开始前必知知识点
    1、什么是GPU,主要用来做什么?   GraphicsProcessingUnit,缩写:GPU),又称显示核心、视觉处理器、显示芯片,是一种专门在​​个人电脑​​​、​​工作站​​​、游戏机和一些......
  • consul原理
    阅读目录​一、使用Consul做服务发现的若干姿势​​​1阅读目录​​启动第1个Server节点,集群要求要有3个Server,将容器8500端口映射到主机8900端口,同时开启管理界面​​​​......
  • MOOD|所以真的是“游戏”的问题吗?
       刚刚我妈抢走了我的手机和平板,因为我在平板上玩游戏。   我没想到这些会发生在一个21岁的人身上。不过好像在我和我妈之间,每天都在发生着一些荒诞且幼稚的事......
  • CF1051E Vasya and Big Integers
    [CF1051EVasyaandBigIntegers](Problem-E-Codeforces)sb的做法单调队列乱整(#include<bits/stdc++.h>#definelllonglongusingnamespacestd;constintN=......
  • Windows环境下安装和配置WNMP的Memcached
    PHP开发不是我最擅长的服务端语言,但是因为接触WordPress很早,了解到一个叫做 ​​WPJam​​​ - https://blog.wpjam.com/article/wordpress-memcached/ 的插件,后来他更......
  • Spring Boot「15」统一异常处理
    持续创作,加速成长!这是我参与「掘金日新计划·10月更文挑战」的第15天,点击查看活动详情今天我们将一块学习下SpringMVC中实现统一异常处理的几种方式。总得来说,统一......
  • JS学习笔记9_JSON
    1.JSON概述JavaScriptObjectNatation,js对象表示法,(像XML一样)是一种数据格式,它与js有相同的语法形式P.S.一点小历史:JSON之父是道格拉斯,《JavaScript语言精粹》的作者,创造JSO......
  • Spring MVC 拦截器实现登录拦截以及多拦截器的配置执行详解
    持续创作,加速成长!这是我参与「掘金日新计划·10月更文挑战」的第25天,点击查看活动详情前言上一篇文章我们简单了解并完成了SpringMVC拦截器的入门案例,这一篇文章,我们......
  • java中 JSONArray 与 List 相互转换
     1.JSONArray转ListList<T>list=JSONObject.parseArray(array.toJSONString(),T.class);//转换语句1 List<T>list=JSONArray.parseArray(array.toJSONString......