zoukankan      html  css  js  c++  java
  • 1 客户端性能--浏览器页面处理

    1.1浏览器页面处理

      浏览器不是批量加载页面的。用户输入URL后,浏览器会并行各项活动,在网络连接的同时进行页面的解析,并将其呈现到屏幕。浏览器执行的这些步骤对用户是可见的,并且很大程度上影响着性能感知和整个页面的加载时间。

    1.1.1网络连接和初始HTTP请求

      浏览器要检索页面,先从URL开始,使用DNS确定服务器的IP地址,然后通过TCP的应用层协议(HTTP)连接到服务器,请求与改URL内容。得到响应后,浏览器再次进行解析,将其呈现给屏幕。与此同时,浏览器还并行的继续进来网络活动,排队或从其他URL请求内容。浏览器通过发送TCP SYN让服务器打开一个连接。服务器确认SYN包做出响应,此时链接被打开。然后浏览器发送一个HTTP GET 包,包括请求的URL、Cookie等数据,浏览器接收后会发送ACK包,这段时间内服务器生成响应。

      然后服务器发送响应,而客户端用ACK包响应,ACK请求的频率由TCP“窗口”大小决定,他是决定网络速度的重要因素。你会看到浏览器请求的响应不会同时到达,在客户端发送包、服务器响应之间会有时间间隔,同时在接二连三的包之间也会有间隔。

      SYN 和 SYN ACK 包加上TCP的慢启动性,致使打开网络连接是很花时间的过程。因此,我们应该避免过多的打开网络连接。

    1.1.2页面解析和新的资源请求

      当IE等待数据包时,他会解析已经得到的包,并且还会寻找其他可用的HTTP请求,并行启动,对于每个服务器来说,浏览器可以同时启用两个连接。

       

      如上图所示,横轴是时间,每一行代表浏览器发起的不同请求,最上一行表示使用DNS解析服务器的IP地址所需要的时间。第二行表示读取主页的时间,最左边的一段表示连接服务器的时间(SYN 和 SYN ACK 包),正好从解析完IP地址以后开始。中间一段是发送初始HTTP GET请求和接收初始的HTTP响应的时间,右边的一段是剩余的响应到达时间。最底下一行是检索图片所需的时间,左边是连接时间,右边一段是初始响应到达的时间。因为图片很小,图片的所有数据都包括在HTTP响应相同的数据包内,所有没有第三段。从第二和和第三行中可以看出,大约到接受HTML过半的时候浏览器才打开服务器的第二个连接,请求图片。因为浏览器一边接收图片,一边解析,而<img>标签离HTML的头部有一段距离,直到几个数据包到达后浏览器才会碰到这个标签。

      

  • 相关阅读:
    linux性能监控 -CPU、Memory、IO、Network等指标的讲解
    Linux中ctrl+z 、ctrl+c、 ctrl+d区别
    linux下程序启动后后台运行实现
    最近纠结致死的一个java报错java.net.SocketException: Connection reset 终于得到解决
    【Unity笔记】将角色的碰撞体朝向鼠标点击方向——角色朝向鼠标
    【Unity笔记】碰撞器(Collision)与触发器(Trigger)的区别
    【Unity笔记】鼠标射线由指定层接收
    【Unity笔记】Awake()和Start()的区别
    【Unity笔记】第三人称相机跟随
    【Unity笔记】经典的鼠标点击射线检测碰撞
  • 原文地址:https://www.cnblogs.com/MaxJoker/p/5344577.html
Copyright © 2011-2022 走看看