译文:前端性能的重要性 The Importance of Frontend Performance

摘要:
TrackingWebPagePerformance跟踪网页的性能,以便找到性能的改进点。第一个名为html的栏用于初始化html文档。因此浏览器无法缓存响应结果。图A-2显示了最多三个并行HTTP请求。然而,在图A-1中,同时出现多达6或7个HTTP请求。在性能黄金法则性能优化黄金法则之前,我们提到只有10-20%的响应时间用于下载HTML文档,而这一现象不仅发生在Yahoo!地点

欢迎訪问我的主页。最新的文章我会首先公布在个人主页上:

http://blog.guaidm.com/shocky/

原书下载地址http://pan.baidu.com/s/1pJocRwB   

    在我的web开发生涯里,大部分时候我都是作为一个后台project师。这样一来,我投入了非常多的精力去研究、练习怎样通过后台优化来提升项目产品的性能,诸如编译器选项,数据库索引。内存管理等。非常多书都花大量篇幅来讲述怎样在这些方面提高性能。非常多人也进而在这方面的优化花了大量时间。说实话,非常多WEB网页,真正花费在webserver到终端用户的时间事实上往往不超过整个响应时间的一两成。

假设你真的想极大幅度地降低web页面的响应时间。你应该把注意力放在真正影响终端用户体验的另外八九成的内容上。那这80%-90%的时间究竟花费在哪了?怎样才干去降低?基于现现在WEB应用的基本原理,本书的下面章节便将来提供14条加速优化法则。

Tracking Web Page Performance
追踪网页性能

    为了可以找到性能的提升点。我们必须知道用户的时间花在哪了。图表A-1展示了当用户用IE浏览器訪问雅虎首页(http://www.yahoo.com)时的HTTP传输情况。每一个横条是一个html请求。第一个名为html的横条是表示初始化HTML文档。浏览器解析HTML文本并開始下载当中的文档元素。

在这个样例中,因为浏览器的缓存为空,所以全部的元素都须要进行下载。下载HTML文档只耗费了全响应响应时间中的5%。所以另外95%的用户等待时间都用在了下载文档节点的详细元素内容上。

当然,还有非常小的一部分时间花在了等待解析HTML、脚本和CSS上。也就是图中两个下载条之中的空白区间。

    图标A-2展示了使用IE浏览器第二次訪问同一个URL地址时候的情况。

HTML文档初始化依然仅仅占用了12%的总响应响应时间。并且绝大部分元素内容不须要再下载了。由于他们已经在浏览器的缓存里。

译文:前端性能的重要性 The Importance of Frontend Performance第1张

译文:前端性能的重要性 The Importance of Frontend Performance第2张

    只是在第二次訪问时。有5个元素还是被请求进行下载了:

    一个重定向:
这个重定向的内容事实上之前就下载过。可是浏览器还是又请求了一次,这回HTTP响应结果是302("Found" 或 "move temporarily") ,而且在返回的报头中并没有不论什么缓存信息。所以浏览器也没办法缓存本次响应结果。关于这个我将在章节B中对HTTP进行讨论。

    三张未进行缓存的图片
接下来之所以三个图片被请求下载了是因为之前第一次訪问时没有被下载缓存过,这三张图是新闻图片和广告图片,所以会被频繁的更换。

    一张已经被缓存的图片
最后一个HTTP请求是一个条件GET请求。

这个图片之前已经被缓存过了,可是因为HTTP的响应报头中的參数设置,浏览器必须在确保图片是最新版本号的图片后才干给到用户。关于条件GET请求也会在章节B中进行讨论。

Where Does the Time Go?
时间都去哪了?

    这么一来。我们发现:至少80%的响应时间是花在了下载页面元素内容上。

当我们去深度挖掘这些图表的细节时,我们将会逐渐看到HTTP与浏览器之间及其复杂的交互过程。之前,我已经提到过HTTP的状态码和报头是怎样影响浏览器的缓存操作的。除此之外,我们还能注意到下面几点:

    1. 在使用了缓存的情况下(图表A-2),并不会有非常多下载请求。相反,你会看到在HTML文档初始化解析完毕后,紧接着出现一段没有不论什么下载记录的空白区域。这一段时间就是用来解析HTML文档,JS和CSS。同一时候也包含了从缓存中取出已有的元素内容。

    2.时刻变化的并行HTTP请求数。图表A-2最多时候出现了3个并行的HTTP请求。然而在图表A-1中却有了多达6、7个HTTP请求同一时候出现。

这样的现象缘于不同域名的数量的影响,而且不管这个使用的协议HTTP/1.0还是HTTP/1.1 。 关于这个问题我们将在章节6“并行下载”中进行深入探讨。

    3. 并行请求并不会发生在脚本被请求时,这是由于在绝大多数时候。浏览器会对除开下载脚本之外的请求进行堵塞。章节6中对此的原因进行了解释。并介绍了怎样利用这样的特点来加快页面载入速度。

    精确找出时间究竟花在哪了。这非常难。可是要找出哪里没花时间,却非常easy——下载HTML文档不费时。与之相关的不论什么的后台处理也不费时。既然这些不费时。那么我们便能够意识到。优化前端中那些费时的东西,是何等重要了。

The Performance Golden Rule
性能优化黄金条例

    之前我们提到了仅仅有10-20%的响应时间被花在了下载HTML文档上,而这样的现象并不仅仅仅仅发生在雅虎站点的首页。

之前的这些数据特点可以很好的适用于雅虎的差点儿全部功能(除了雅虎的搜索功能,由于那个搜索页的元素实在太少了)。

而且,这些统计数据相同适用于绝大部分站点。

表格A-1展示了http://www.alexa.com选出的美国十大站点。当然有点小修改:除了AOL以外其它都是美国十大站点,当中Craigslist.org位列当中。可是该站点差点儿没有图片。脚本和CSS,所以实在是没办法成为一个好的样例。所以我换做把AOL选入进来了。

译文:前端性能的重要性 The Importance of Frontend Performance第3张

    相同的,差点儿全部的站点都是在仅仅将低于20%的响应时间用在下载HTML文档上。当中唯一的一个列外是在有缓存环境下的Google。这是由于http://www.google.com总共仅仅有6个文档元素,除了一个元素以外,其它的全部元素都被设定为浏览器缓存处理。在之后的訪问中,由于这些元素都已经被缓存了,就仅仅剩下HTML文档请求和一个image beacon。

    在全部的性能优化中。最关键的是通过刻划界定当下的性能表现。来指出哪里才是真正可以大幅度提升行性能的要害之处。

非常明显。前端才是我们真正要关注的性能优化点。

    首先,优化前端对整体性能的提升蕴藏着巨大的潜力。我们把后台系统处理的花费时间减半,那终端用户的响应时间无非就是缩短5-10%;相反,假设我们在前端上将时间减半,将能够缩短总响应时间的40-50% !

    其次。前端性能优化通常花费的时间更少,所需的资源也更少。

要缩短后台的等待时间。我们往往会不可避免地要做各种的事情,比方又一次设计架构与代码,找到并优化有问题的代码分支,加入或改动硬件设备,数据库分布式搭建等等。这些事往往须要花费几周乃至几个月时间。而我们之后一些章节要提到的前端性能优化措施,将都是更利于实际操作的最佳实践方案。诸如改动WEBserver配置(章节3、4)。变更脚本和CSS在web页面中的位置(章节5、6)。合并图片、脚本和CSS(章节1)。

而这些工作只花费几个小时或者几天——这远远低于后台优化所需的时间。

    再有,前端优化的实际价值已经得到印证。

在雅虎,超过50个团队通过使用这些最佳实践方案。成功减少了终端用户的响应等待时间,缩减比例非常多达到了25%甚至很多其它。当然。在非常多时候。我们必须不拘泥于这些法则,依据站点的详细情况进行更详细的分析与优化,可是一般来说。通过这些最佳实践,提升25%的性能甚至更高,这都是全然有可能的。

    在每一次開始进行行性能优化的时候。我都会画一个像类似A-1的图表。然后注明上性能优化的黄金法则:

     10-20%的时间事实上使用来下载HTML文档,其它的80-90%时间是在下载页面元素。

    本书的其它部分将会精确细致的介绍这些怎样减少这80-90%的耗费时间。为了说明清楚这些,我将会囊括非常多方面的技术:HTTP请求头、JavaScript、CSS、Apache 等等。

    考虑到HTTP的基础概念是理解本书的关键所在,我将这一块单独提升到了章节B来进行讲述。

    在章节B后便是提升性能的14条法则,每一条法则一个章节。这些法则依照我们通常理解上的优先顺序来进行排序。当然,一个法则是否可以非常好的适用于你特定的站点,这个要是详细情况而定。举例来说。法则2更适应于商业站点而并不是适用于个人站点。假设你採用了全部的适合你的站点的优化手段。你将可以让你的页面訪问速度提升25-50%,同一时候大大改善用户体验性。本书的最后章节展示了怎样从性能角度来分析美国的十大站点。




免责声明:文章转载自《译文:前端性能的重要性 The Importance of Frontend Performance》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇C# XML序列化实例学习如何管理 node 的多个版本下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

HTTP认证方式与https简介

HTTP认证与https简介# HTTP请求报头: Authorization    [ˌɔ:θəraɪˈzeɪʃn] HTTP响应报头: WWW-Authenticate    [ɔ:ˈθentɪkeɪt] HTTP认证是基于质询/回应(challenge/response)的认证模式。 HTTP认证 BASIC认证 BASIC认证概述 当一个客户端向...

[Linux] nginx记录多种响应时间

官网介绍$request_time – Full request time, starting when NGINX reads the first byte from the client and ending when NGINX sends the last byte of the response body$upstream_connect_tim...

前端项目里常见的十种报错及其解决办法

错误一:Uncaught TypeError: Cannot set property 'onclick' of null at operate.js:86 图片.png 原因:当js文件放在head里面时,如果绑定了onclick事件,就会出现这样的错误,是因为W3School的写法是浏览器先加载完按钮节点才执行的js,所以当浏览器自顶向下解析...

EasyDSS高性能流媒体服务器前端重构(六)- webpack-dev-server 支持手机端访问

很多时候,前端开发的页面,不仅要在PC端测试效果, 还要在手机端测试效果. 在开发阶段, 我们以 webpack-dev-server 来启动浏览器, 打开正在开发的页面. webpack-dev-server 可以做到实时监听文件修改, 自动更新浏览器中的网页, 一旦代码发生修改, 无须人工干预, 页面就同步到最新状态. 但是 webpack-dev-s...

CSS 属性选择器的深入挖掘

CSS 属性选择器,可以通过已经存在的属性名或属性值匹配元素。 属性选择器是在 CSS2 中引入的并且在 CSS3 中得到了很好拓展。本文将会比较全面的介绍属性选择器,尽可能的去挖掘这个选择器在不同场景下的不同用法。 简单的语法介绍 [attr]:该选择器选择包含 attr 属性的所有元素,不论 attr 的值为何。 [attr=val]:该选择器仅选...

关于浏览器对html, js,css的解析先后顺序的理解

1.首先要了解页面的结构(包含哪些元素?哪些计算机语言能够在页面中运行 ) (1)html          不仅可以包含文字,还可以包含图片、链接,甚至音乐、程序等非文字元素的标记语言          (展示给用户,不能太单调,css) (2)css          是一种用来表现HTML的计算机语言,能使HTML页面变得更加美观        ...