译文:前端性能的重要性 The Importance of Frontend Performance
欢迎訪问我的主页。最新的文章我会首先公布在个人主页上:
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%的总响应响应时间。并且绝大部分元素内容不须要再下载了。由于他们已经在浏览器的缓存里。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWFuZ3h5ODExMTg=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
只是在第二次訪问时。有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选入进来了。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWFuZ3h5ODExMTg=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
相同的,差点儿全部的站点都是在仅仅将低于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的更多相关文章
- 如何合理优化WEB前端 高效提升WEB前端性能
对前端开发工程师来说,前端性能优化的重要性是不言而喻的,最为大家所知的是YSLOW的23条优化规则,在我的理解中,性能优化不纯粹是指用户访问网站的速度,也包括开发的效率,这里我总结下我理解中的WEB前 ...
- Web前端性能优化教程05:网站样式和脚本
本文是Web前端性能优化系列文章中的第五篇,主要讲述内容:网站样式和脚本代码的放置位置.使用外部javascript和css.完整教程可查看:Web前端性能优化 一.将样式表放在顶部 可视性回馈的重要 ...
- Web性能API——帮你分析Web前端性能
前端性能统计必备api,有不知道的吗? 正文从这开始- 开发一个现代化的互联网网站是一项复杂的任务,需要各种职能的密切合作以应对用户日新月异的需求.其中,网页的性能直接决定了用户的体验,而随着新型客户 ...
- WEB前端性能优化:HTML,CSS,JS和服务器端优化
对前端开发工程师来说,前端性能优化的重要性是不言而喻的,最为大家所知的是YSLOW的23条优化规则,在我的理解中,性能优化不纯粹是指用户访问网站的速度,也包括开发的效率,这里我总结下我理解中的WEB前 ...
- WEB前端性能优化小结
转:http://www.gafish.net/archives/1514 对前端开发工程师来说,前端性能优化的重要性是不言而喻的,最为大家所知的是YSLOW的23条优化规则,在我的理解中,性能优化不 ...
- OneAPM x 腾讯 | OneAPM 技术公开课·深圳 报名:前端性能大作战!
「 OneAPM 技术公开课」由应用性能管理第一品牌 OneAPM 发起,内容面向 IT 开发和运维人员.云集技术牛人.知名架构师.实践专家共同探讨技术热点. 11月28日,OneAPM 技术公开课第 ...
- Web前端性能优化进阶——完结篇
前言 在之前的文章 如何优化网站性能,提高页面加载速度 中,我们简单介绍了网站性能优化的重要性以及几种网站性能优化的方法(没有看过的可以狂戳 链接 移步过去看一下),那么今天我们深入讨论如何进一步优化 ...
- 合理提升WEB前端性能
前端的优化包括四个部分:HTML结构优化.CSS样式优化.JS行为优化.服务器的优化.合理的前端优化不仅能够提升网站加载速度,而且能够更好的提升用户体验和团队开发效率.所以前端性能优化的重要性是不言而 ...
- 【HTML】前端性能优化之CDN和WPO的比较
CDN通过将资源存储在更接近用户的位置,缩短到服务器的往返行程,加快页面加载时间来解决性能问题.WPO解决方案,如Radware的FastView,则在前端进行性能提升处理,使页面更有效地呈现在浏览器 ...
随机推荐
- linux添加、修改环境变量
比如要把/etc/apache/bin目录添加到PATH中,方法有三: 1.In shell: setenv <path_to_append>: $ENVNAME setenv PATH ...
- Uniconnection 连 mysql 有时会断线的
你定义localfailover:=ture.断线后会自己接上 firedac没这种功能.只有unidac有
- linux c coding style
Linux kernel coding style This is a short document describing the preferred coding style for the lin ...
- 基于visual Studio2013解决算法导论之054图的邻接矩阵表示
题目 图的邻接矩阵表示 解决代码及点评 // 图的邻接矩阵表示.cpp : 定义控制台应用程序的入口点. // #include <iostream> #include <l ...
- xen虚拟机安装实践
xen虚拟机环境安装,用了2天的时间摸索,终于出来了,给大家分享一下. 1.安装宿主环境,我使用的是Centos6.3 2.安装xend,参考了一篇老外的文章,基本比较顺利. 地址:http://xe ...
- [置顶] 深入ResourceBundle
ResourceBundle是java开发中非常实用的一个类,主要用来处理应用程序多语言这样的国际化问题. 如果你的应用程序如果有国际化的需求,可以考虑使用ResourceBundle, 你要做的就是 ...
- [置顶] Android开发之XML文件的解析
Android系统开发之XML文件的解析 我们知道Http在网络传输中的数据组织方式有三种分别为:XML方式.HTML方式.JSON方式.其中XML为可扩展标记语言,如下: <?xml vers ...
- Android--pendingIntent & Intent
PendingIntent pendingIntent字面意义:等待的,未决定的Intent.要得到一个pendingIntent对象,使用方法类的静态方法 getActivity(Context, ...
- 02-OC方法、属性
目录: 一.方法 二.实例变量 三.属性(点语法) 四.初始化方法(自定义构造方法) 回到顶部 一.方法 1 函数与方法有什么区别? 函数只是一个程序的代码段,与类无关. 方法,类的一部分,代表对象可 ...
- Robot Framework: 自定义自己的python库
利用Robot Framework编写测试用例,往往需要开发自己的关键字,有的关键字需要通过自己编写python代码来实现.这在rf中,就需要自己定义python库.这个过程其实不复杂,本文来介绍下. ...