Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3024937
  • 博文数量: 454
  • 博客积分: 4860
  • 博客等级: 上校
  • 技术积分: 6375
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-13 10:08
个人简介

10年工作经验,专研网站运维。

文章分类

全部博文(454)

文章存档

2017年(11)

2016年(13)

2015年(47)

2014年(36)

2013年(147)

2012年(64)

2011年(136)

分类: LINUX

2011-11-18 11:13:24

yslow

 

安装 YSlow

先安装 Firebug 

Firebug 帮助文档 .

再下载安装  http://developer.yahoo.com/yslow

 

使用Yslow

Yslow
是运行在Firebug窗口下,所有要运行Yslow,必须安装Firebug

有两种方法启动Yslow

       1
、打开Firebug窗口,选择Yslow选项。

       2
、直接点击浏览器右下角的Yslow启动按钮。

你第一次打开Yslow时,以下图像作为Firebug的一部分被显示在的浏览器窗口。

点击 Run Test 运行Yslow,也可以点击 Grade, Components, Statistics选项开始对页面的分析。

你可以选择 AutorunYSlow each time a web page is loaded 它将自动对以后打开页面进行分析,您也可以右击YSlow状态栏,然后选择或取消自动运行。

 

Yslow视图

YSlow显示测试结果的分析,分为等级、组件、统计信息。你可以浏览这些观点之间选择标签以观的名字在YSlow标签的Firebug控制台。

以下是说明的等级、组件、统计信息。

一、等级视图

  查看一个分析,选择页面的性能等级标签或点击网页的字母等级在状态栏这页纸的底部。

视图显示了等级为网页的成绩单。整个字母等级为页面显示在顶部随着全面数值的表现。这个页面是基于22可分级的高性能网页的规则(性能规则)。这些规则是列在按重要性的顺序,从最重要不重要。从 A 级到 F 级,A 级为最高。

下面是一个等级的例子:

如果页面与某一个规则无关,则显示 N/A ,表示不适用。

点击每一规则,都给出了改进建议。要查看更全面的改进方法进入前端性能优化指南

二、组件视图

分组显示页面组件,表格列出组件的信息,点击 Expand All展开显示给个分组内各的组件信息。

下面简要列在组件检视表:

TYPE:该组件的类型。该网页是由组成部分的下列类型: doc, js, css, flash, cssimage, image, redirect, favicon, xhr, and iframe.

SIZE(KB):该组件的大小以千字节。

GZIP(KB):该组件的gzip压缩的大小以千字节。

COOKIE RECEIVED(bytes):字节数在HTTP设置的Cookie响应头。

COOKIE SENT(bytes):节数的CookieHTTP请求报头

HEADERSHTTP信息头,点击放大镜查看全面信息。

URL:链接地址

EXPIRES(Y/M/D):日期的Expires头,属于缓存设置一种。

RESPONSE TIME (ms):响应时间

ETAGETag响应头,也是缓存设置的一种

ACTION:额外的性能分析

三、统计信息视图

 左侧图表显示是页面元素在空缓存的加载情况,右侧为页面元素使用缓存后的页面加载情况。我们可以看到,页面元素缓存后的使页面的http请求和页面总大小都减少,从而加快了页面打开时间。参看(页面的缓存设置

YSlow菜单栏

 

一、规则集

     1 YSlow 2版) -这一规则集包含了所有22个测试的规则。
     2
、精英( V1导联) -这个规则集包含原始13规则中使用了YSlow 1.0
     3
、小网站或博客-这个规则集包含14个规则,适用于小型网站或博客。参照下方的图片,看看哪一种规则,在这个规则集。

请注意,最后选定的规则集成为默认的规则集。默认规则集可以是一个预定义的三个之一或您自己创建的一个。

要创建您自己的规则集,单击Rulesets下拉菜单旁边的 Edit 按钮。新的规则集屏幕将显示:

    1、点击左侧 New Set 按钮,出现全部22调规则,勾选你所需的

    2、点击 Save ruleset as... 保存,会弹出个命名窗口,命名就可以了。

    3、你还可以对自定义的规则再次编辑或者删除。

 

YSlow 工具

YSlow的工具菜单上提供了多种报告工具,您可以使用获得的信息,以帮助您的网页分析。以下是截图工具菜单:

1JSLint

JSLint收集所有外部和内部的JavaScript从目前的网页,提交给JSLint ,一个JavaScript验证,并打开一个单独的窗口了一份报告,存在问题,该网页的JavaScript的。该报告包括大致位置的源代码的问题。很多 时候,这些问题是语法错误,但JSLint寻找风格公约的问题和结构性问题。

2All JS

收集所有外部和内部的JavaScript的网页,并显示在一个单独的脚本窗口。您可能想要使用这个工具来查看某个脚本,以及是否实际使用是正确的。

3All JS Beautified

js以人们可读的方式展示。

4All JS Minified

收集所有外部和内嵌JavaScript,删除评论和白色空间以缩小的脚本。以改善网页的性能。

5All CSS

收集所有的行内和外部的样式表在网页上,并将其显示在一个单独的窗口。

6All Smush.it

如果您按一下所有Smush.it Smush.it将运行在网页上所有的图片组成。此工具将告诉你该图像可被优化,并创建一个压缩文件,来优化图像。当您选择此工具你会看到输出如下所示:

以上就是Yslow的使用指南,结束。

 

Best Practices for Speeding Up Your Web Site

首先的说明的是:优化页面显示速度,就是不管HTML内容多与少,都要尽量在最快的速度显示出来,这就是Front-end engineers首要明确的意图。所以下面所提及的优化方式,都是从这一目的出发的。下面的翻译的一些条目:

1.最小化HTTP request请求。因为一个页面显示所花费的时间很多都是花费在scriptsstylesheetsimagesflashs等等,这些都会通 过http request来加载,这些大概占用了页面加载时间的70%-80%,因此,减少HTTP request能很大的优化页面的加载速度。

2.使用第三方的代理服务器来加载scriptsstylesheets等等,这能降低本主服务器的负载,比如google ajax api提供的目前流行的js库:jqueryextjsprototypeMooTools等等

3.在头部声明cacheexpire。在用户第一次view页面的时候会加载全部的内容,包括html以及 scriptsstylesheetsimages等等,设置了cacheexpire一方面能使得用户在下次view页面的时候能从缓存里读取一 些数据,减少了HTTP Request的请求数,加快页面的显示。不过这要看用户view页面的回头率是否频繁。设置了cacheexpire也要适当。一方面能加快加载速 度,另一方面也有助于在cacheexpire过期的时候使得用户获得页面的最新数据信息。

4.使用压缩技术(Gzip Components)。原理就是将scriptsstylesheetimagesflash等等压缩为一个zip文件,之后把这个zip文件链 接进页面中来减少http request回调来加快页面的加载速度。通过摄自豪HTTP headerAccept-Encodinggzip, deflate,之后在Response header里设置Content-Encoding: gzip来解压压缩包的文件,就可以将这些文件导入到页面的相应的部分。不过,如果页面中的Component比较少或者也是相对于非常小的话,还是不建 议使用这种方法,还是使用普通的通过各自的连入方式加载Component

5.将全部的Stylesheets放到head里来加载。Yahoo测试了这种方式证明了这一方式确实能加快页面的加载速度,“This is because putting stylesheets in the HEAD allows the page to render progressively.”

6.Scripts放置到Bottom(底部)。我们都知道,通过script标签引入文件会阻止下面的HTML内容的加载,等待script加载文件 完成才加载下面的内容。因此:HTTP/1.1 specification建议在每一个主机名下不要超过两个Component同时下载。还有一点要说明的是:当script正在加载的时候,浏览器机 会停止一切其他的加载项,甚至不同的主机下的文件都不会加载(通过iframe加载的内容)。
但是有时候有很难将scripts都放到bottom里,这里的主要问题就是通过document.write来添加页面内容以及作用域问题。因此,就需要使用其他的方式来解决这样的问题了。
这里有一种建议方案:就是使用deferred scripts(延迟执行scripts),通过使用script标签的defer属性来延迟执行不包含document.writejs代码。 defer的机制就是先加载好scripts,之后在DOM加载完成之后,执行js代码(defer的延迟要比window.onload早),因此使用 defer会在DOM加载完成,window.onload之前执行js代码。但是defer属性目前只有IE支持,Firefox等浏览器不支持,要通 过检查DOM是否加载完成这样的方式来解决。因此,如果一个script可以defer延迟的话,同样也就可以把它放置到bottom里,这样就能加快页 面的加载(显示)速度。

7.避免使用cssExpressionsCSSexpression虽然很强大,能动态修改css的样式规则,只有IE能识别expression属性。
但是,致命的问题在于:它执行的非常的频繁,页面的一个renderresizescroll,以及用户的一些简单的鼠标操作,比如:移动鼠标等等都会触发expression的重复执行。一个测试表明:在页面内移动鼠标就非常容易的产生超过10000次的执行次数。这将是难以想象的耗费性能。
一种解决办法就是一次执行expression之后,就给css 样式指定确切的值,而不在需要依赖expression

8.通过外联的方式来加载外部的Javascriptcss到页面里。在第一条里我们谈到减少Http request请求来加载Component,而这里又提倡使用外联的方式来加载scriptsStylesheet等等Component,不是冲突 了吗?这里来解释一下:如果不是通过外联的方式来加载文件,这样在每次加载页面的时候,都需要去加载内联的Javascriptcss内容,这就使得 HTML容量变大了。而使用外联的方式的好处在于浏览器会缓存这些文件,第二次加载页面的时候就会在缓存里读取这些文件(如果缓存里还没有清除的话),这使得HTML页面变小了,不是更快加载HTML了吗。从这一角度来考虑,视具体情况而定,来综合考虑上面所提到的几种优化方案。

9.压缩Javascriptcss代码。压缩代码就是清除掉一些不需要的characters,减小代码文件的大小,从而加快加载。可以通过使用或者YUI Compressor,还有等等压缩工具。压缩代码的范围可以很广泛,包括独立的js或者css文件,当然也可以是内联的js或者css代码(google就使用了这种方式),也可以是上面所说的通过压缩Components联入页面的各个js或者css文件。

10.删除重复的Scripts Component。有时候如果不加注意,可能就会重复加载了同一个script联入文件,比如通过script联入,之后在某种形式下使用php insertScript又联入了同一个文件,这都是有可能的。这将会有哪些不合理呢:一个是花费Http request的数目而且还会影响浏览器的缓存方面的问题,使得script重复加载。

11.使Ajax可以缓存。Ajax在我们看来是用于跟服务器异步传输数据的,每一步都需要新的数据。当然这是我们都计较长涉及到的,但是某些情况 下,Ajax缓存同样重要,说个比较简单的例子:比如用户通过搜索(当然这个搜索是通过Ajax形式)来观看一些书籍的内容的时候,因为书籍内容是分章节分页面的,而且内容都基本会保持不变,当用户搜索同一文章而且Last modified没有修改的情况下,就可以从缓存里返回上次的搜索内容,而不必重新搜索,从后台传输数据了。

12.Ajax Requests中使用GET方式。YahooMail团队发现当使用XMLHttpRequest的时候,使用POST方式在浏览器会执行两部操作:先发送headers信息,之后发送data数据。而GET方式只需要“take one TCP packet”。但是IE中对于URL长度的限制在2K之内,所以data超过2K的话还是需要使用POST的方式。

13.延迟加载一些Components。我的理解是这样的:对于页面中一些不需要在页面中即刻需要显示出来的效果或者内容的时候,可以延迟加载这些内容。比如Javascript中的拖动以及一些暂时隐藏的内容等等,这些都可以在页面其他的内容加载完之后再去加载它。这就不会影响整体的页面的显示速度了。

14.预先加载Components。这似乎跟上面的延迟加载Components有冲突,但是不尽然。这里的情况是这样的:在浏览器空闲的时候(比 如:onload之后)预先加载ComponentsimagesscriptsStylesheets),这样在用户浏览其他页面的时候,当其他 页面中使用到了这些Components的时候,就可以直接在Cache里读取,而无需重新加载。

15.减少DOM Elements。这就涉及到HTML页面的架构问题了,可以想象,当一个页面中存在500或者5000DOM Elements的时候,在页面加载的时候,DOM渲染速度,将会是一个怎样的区别。所以,这也要求设计HTML页面架构的时候能保持简洁和语意化。使得 DOM Elements尽量的少,提高DOM渲染速度。

16.减少页面中的iframes数量。我们知道,iframe可以将其他页面嵌入到当前页面中。但是懂得它的运行方式将会非常有用。

好处是:是一个安全的沙箱;可以平行的下载scripts;减缓第三方内容的显示比如广告等。
坏处是:花费时间来加载页面内容如果链接到一个空页面或者一个不存在的页面;打断了页面的onload进程。

17.避免404错误的出现。404错误是没有找到指定URL的页面,出现这个错误页面的时候也是很耗费时间的,而且它很糟的一个方面是当用户等待了几秒甚至更长的时间来等待页面显示,最后显示出来的是404错误,用户体验度明显下降了。还有一个很糟的方面是如果通过script外联的 Javascript文件找不到,这一方面会打断页面的加载进程,另一方面也使得页面的功能逻辑缺失。

18.减小Cookie的大小。HTTP cookies在存储一下私人信息等方面,但是Cookie是通过HTTP headers在服务器端和客户端之间交换的。所以就非常有必要去尽量减小cookie的大小,使得用户的response time的影响最小化。
When the cookie Crumbles一篇文章里详细分析了Cookie,它指出:
a.
去除一下不需要的cookies
b.
尽量使得cookie最小化以简短用户的response time
c.
适当的设置cookieexpire过期时间。
d.
在设置cookiedomain的时候要非常小心,使得其他的sub-domains不会受影响。

19.要明智的设置Event Handlers。有时候页面感觉反应迟钝或者缓慢,一个方面是因为页面中的event handlersDOM Elements里设置的太多了,事件通过冒泡或者捕获等等导致事件发生的太频繁。要根据实际情况,明智的设置Event heandlers

20.外联css文件选择 而不是@import。上面我们提到了将css外联文件都放置到head部分里,这样可以加快页面加载速度。对于@import语法,在IE下等同于使用 外联css文件并放置到bottom里了,所以不推荐使用@import的方式。

21.避免使用Filters。我们知道,IEcss的滤镜可以通过filter属性来设置很多华丽的效果。但问题是filter一方面打断页面的渲染和当图片在加载的时候冻结了浏览器;另一方面也是增加了内存的消耗。
所以,应该避免使用filter滤镜,使用更好的PNG8来代替,如果非要使用,请使用_filter,使得用IE7的用户能有一个更好的用户体验。

22.合理的使用各种格式的image。图片有gifpngjpg等这三种是网页比较常用的三种格式,但是知道这三种格式的图片特性,合理的使用,也是非常有必要的。
gif
一般文件都比较小,但是只有256种颜色。
png
最大的一个特点就是支持透明度。
jpg
以它的高清晰度而为人所用。

23.使favicon.ico尽量小并可以缓存。很多网站都设置了favicon.ico一个小图片在浏览器的URL地址栏里显示。这非常好。但是 favicon.icocookie以及其他的Components一样都是需要Http request加载的,所以尽量保持它能被浏览到(避免出现404错误)和可以缓存,就显得十分有必要了。下面是关于favicon.ico的两项建议:使得favicon.ico保持在1K以下;在header里合理设置Expire过期时间。

24.保持全部的Components的大小在25K以下。这个限制的原因是由于iPhone的机制:如果超过25K,它就不会缓存页面的Components。因此为了页面跟iPhone兼容,合理减小Components也是有必要的。

上面的翻译是根据自己的英语水平以及自己对于它们的一点见解,有错误的地方在所难免,本人都苦于没有中文版的介绍。所以干脆自己在浏览过后小译一番,也方便自己以后对它的理解吧。但是本人还是推荐对这方面感兴趣的朋友去阅读原文。

 

前端优化之Page Flushing

Page Flushing的目的在于让让浏览器尽可能快的得到数据,以便渲染,在PHP里有一个flush函数很有用:







通过在head后面放置flush,即便后面的内容还没有生成,也可以先让客户端得到头部的内容,从而尽快开始下载css数据(这里我没说js,因为从完美角度看,js应该尽可能放在页面尾部,而不是放在head里),如此一来速度会快一些,从而改善前端的用户体验。

head后放置flush是最常见的方法,但不便于演示,下面看看在body中使用flush的例子:



DEMO


hello


world





注意:因为有的PHP环境会打开输出缓冲,所以上面使用了ob_flush方法排除这种情况。

使用Firefox浏览上面代码,就能看到效果了,但是如果你使用IE浏览的话,会发现无效,原因在PHP手册中对flush函数的描述里已经说得很清楚了:

Some versions of Microsoft Internet Explorer will only start to display the page after they have received 256 bytes of output, so you may need to send extra whitespace before flushing to get those browsers to display the page.

也就是说如果内容太短的话,IE会先缓冲内容,到了一定的长度再输出,如果你遇到了这个问题,可以发送空白字符来凑数。

最后再说一个问题:



DEMO






long string...


long string...





这段代码和上面的代码相比,多了一个页面级的table包裹,如果这样设计话的,即便使用了flush,但由于table标签标签未闭合,所以浏览器不会立即开始渲染,必须等到table标签闭合才可以,如此一来,flush就无意义了,不过经过测试,我发现虽然IE有这个问题,但Firefox似乎不受影响,可不管怎么说,在使用Page Flushing技术的时候,还是应该尽可能避免页面级别的元素包裹,把内容打散,多多使用flush

补充:flush仅在php作为apache模块安装时才有效,如在ngxin下以fastcgi方式安装php,那么当运行flush的时候,缺省无效果,nginx通过自己控制输出,按照官方文档描述,可以通过设置0来关闭fastcgi_buffers,但经过测试发现还是不能达到预期效果,如果想达到类似的效果,必须设置一个较小的fastcgi_buffer_size,并且关闭gzip

补充:很多模板引擎有block功能,可以在block开始和结束的时候加上钩子,整合这个功能。


设置Gzip压缩

模块

LoadModuledeflate_module modules/mod_deflate.so

DeflateCompressionLevel 9

AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-httpd-php

AddOutputFilter DEFLATE jscss

 

DeflateCompressionLevel9

其中9为压缩等级不要设置太高否则会影响客户以及服务器CPU使用率

AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-httpd-php

文件类型为html, PHP

AddOutputFilter DEFLATE jscss

文件类型为 JS,CSS

设置 Expires(过期)

模块

LoadModuleexpires_module modules/mod_expires.so

ExpiresActive On

ExpiresDefault A2592000

ExpiresByType image/x-icon A2592000

ExpiresByType application/x-javascript A2592000

ExpiresByType text/css A2592000

ExpiresByType image/gif A2592000

ExpiresByType image/png A2592000

ExpiresByType image/jpeg A2592000

ExpiresByType text/plain A86400

ExpiresByType application/x-shockwave-flash A2592000

ExpiresByType video/x-flv A2592000

ExpiresByType application/pdf A2592000

ExpiresByType text/html A2592000

ExpiresByType text/js A2592000

ExpiresByType image/jpg A2592000

设置ETag(文件缓存)

模块

#FileETag none

(所有的.so的文件阿帕奇安装时是都带的只有模块内容是需要自己加的)

  CDNContent Delivery Network),即内容分发网络,用于加快网络访问速度,解决电信、网通、铁通、移动、联通、教育网之间互联互通速度慢等问题,使用后能够大幅提升网站流量。


 

阅读(2218) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~