对应的网站速度优化方法略谈

Yahoo!曾经针对网站速度体验提出了34条宝贵的准则《Best Practices for Speeding Up Your Web Site 》,而Yslow 正是按照这些准则,评测一个网站在速度体验上的优化程度的Firefox插件,将34条精简为更加直观的13条,并针对每一条给出从F~A的评分以及最终的总分。

当然从评测得到的只能是一个分数以及建议,如何改进还是要靠自己,这里要谈的就是实实在在的如何针对每一条进行优化:

1. Make fewer HTTP requests / 减少Http请求数

一个网页不可避免的要引入大量的外部文件:Javascript、css、背景图片……由于Http协议的无状态性,用户的每一次访问,都会重新向服务器请求所有文件,而大量Http请求的累加,正是影响网站速度的最主要原因。

所以这里的解决方法只有一个:合并。最理想的情况莫过于一个网页只包含一个css,一个js,一张背景图。

合并Js和Css文件很好理解,背景图片要怎么合并?这里采用的主要方法是CSS Sprites,简单说就是把所有的图片拼接成一张大图,在不同的Css里指定背景图坐标来显示不同图片。具体可以参考Dave Shea的Image Slicing’s Kiss of Death 一文,还有网站提供了在线的CSS Sprites服务 ,只需要上传小图片,就可以获得拼接后的大图以及相应坐标。

不过在当前越来越多动辄包含10余个文件的开发框架面前,减少Http请求数也变得越来越难。一直都认为所谓框架,给出的应该是一整套完善的开发思 想,从服务器配置到数据库设计甚至是到UI体验乃至SEO,但现在很多Framework总是各自为战,后台与前端脱节,只在自己的一片领域里提供一定程 度上的方便,没有考虑到最终产品的统合,甚至连基本的代码侵入性问题没有处理好(这里点名批评dojo,恨不得在所有的html标签上印上dojo的章 子),不能不说是一种遗憾。

所以如果网站中采用框架的话,在框架的选择面前,建议多采用轻量级,侵入性低的框架,也是为了日后产品的优化维护着想。

2. Use a CDN / 使用CDN

CDN(Content delivery network)内容分发网络,能够智能根据网络节点情况选择服务节点,大型网站部署时尤为重要。不过这属于硬件级别的解决方案,我们没有条件配置CDN的时候,可以自行设置忽略这一项评测。

在Firefox地址栏键入about:config,然后新建一个字符串,名称为 extensions.firebug.yslow.cdnHostnames,值为所要评测网站的域名,多个设置用逗号分隔。例如我的设置就是 allo.ave7.net,localhost

3. Add an Expires header / 为文件头指定Expires

Expires是浏览器Cache机制的一部分,浏览器的缓存取决于Header中的四个值: Cache-Control, Expires, Last-Modified, ETag。这个项目的考评主要针对Cache-Control和Expires。

具体的Cache原理不是本文所涉及的,有兴趣的同学可以看看Caching Tutorial 一文。为了优化这个选项,我们所要做的是对站内所有的文件有针对性的设置Cache-Control和Expires,这里基于Apache主机举例:

首先开启mod_header 模块,在httpd.conf中取消

LoadModule headers_module modules/mod_headers.so

一行的注释。然后对于图片,文件等不会经常更新的文件设置一个比较长的过期时间

<FilesMatch "/.(ico|pdf|flv|jpg|jpeg|png|gif|js|css|swf)$">

Header set Expires "Thu, 15 Apr 2010 20:00:00 GMT"

</FilesMatch>

对于Cache-Control可以设置的更加细致一些,这里我对图片,文件设置了1周,对XML,TXT设置了5小时,对html和php文件只设置了1小时。

<FilesMatch "/.(ico|pdf|flv|jpg|jpeg|png|gif|js|css|swf)$">

Header set Cache-Control "max-age=604800, public"

</FilesMatch>



<FilesMatch "/.(xml|txt)$">

Header set Cache-Control "max-age=18000, public, must-revalidate"

</FilesMatch>



<FilesMatch "/.(html|htm|php)$">

Header set Cache-Control "max-age=3600, must-revalidate"

</FilesMatch>

另外Expires也可以通过开启mod_expires 来实现,这里不再举例。

4. Gzip components / 启用Gzip压缩

HTTP/1.1支持接收服务器端经过Gzip 压缩的数据,在Apache2中,可以开启mod_deflate 实现。

同样去掉注释

LoadModule deflate_module modules/mod_deflate.so

然后对所有文本类文件添加Gzip处理

DeflateCompressionLevel 3

<FilesMatch "/.(php|htm|html|js|css)$">

SetOutputFilter DEFLATE

</FilesMatch>

5. Put CSS at the top / 将Css文件放在头部

很好理解的一条,主要是为了避免最后加载Css引起的浏览器白屏,改善用户体验。

6. Put JS at the bottom / 将Js文件放在底部

同样很容易理解,为了让DOM先行加载。

7. Avoid CSS expressions / 避免CSS expressions

CSS expressions可以轻易的引起浏览器假死,也不在W3C规范内,不只是避免,最好完全不要用。

8. Make JS and CSS external / 将Js和Css文件独立

将Js和Css文件单独做成外部文件加载,一则可以功能复用,二则可以生成缓存,当然这一条和第一条要互相参照找出最好的解决方案才是。

9. Reduce DNS lookups / 减少DNS查询

外部文件分散于多个服务器,连接每台服务器都会做一次DNS查询,这一条是针对多服务器的部署。

10. Minify JS / 压缩Js文件

压缩Js文件,Yahoo!官方推荐的工具是JSMinYUI Compressor

11. Avoid redirects / 避免重定向

每一次的重定向都会重新发送Header请求。所以在Apache下,无比强大的mod_rewrite 是必须要学的。

12. Remove duplicate scripts / 移除重复的脚本

开发中没有规划好,会出现页面中重复引用一个文件的情况,IE中即便是重复引用也会重新向服务器发送一次请求。

13. Configure ETags / 配置ETags

在第三条中已经对浏览器缓存机制中的Cache-Control和Expires进行了配置,这一条评测的是另外两个:Last-Modified和ETag

简单的说,即使设置了文件的期限,浏览器在访问资源时往往会因为Last-Modified和ETag而重新下载整个资源,所以简单的做法是关闭Last-Modified和ETag

在Apache中做如下配置

FileETag None



<FilesMatch "/.(ico|pdf|flv|jpg|jpeg|png|gif|js|css)$">

Header unset Last-Modified

</FilesMatch>

最后看看优化后的成果

 

 

 Apache服务器调整原因
1去掉Server 版本,只保留 Apache 显示版本不利安全
2如果Etag 没有进行设定,请去掉 Etag 标签 分布集群会不一致
3增加js,css,ico,png,gif,jpg 的缓存输出,即 Expires 时间,可以适当长一点 减少请求
4对文本类型的输出进行deflate/gzip 压缩 可以减少2/3 的大小
   
   
 文件调整原因
1自定义的css/js 请增加版本号,例如 main.css?ver=20102910011   减少不必要的请求
2对于Logo 图片等也可以增加类似的版本号,默认让 server expires 的时间长一点
3小图片合并,使用CSS 切割(目前发现已经采用了这个方法) 减少请求量
4使用js 压缩算法,压缩 js( 目前好像已经也采用了 ) 可以减少1/4 大小
   
 页内容的输出调整原因
1在输出页面的<head></head> 标签之间。在 <link> css 标签之前,应该加入一个空 js 载入标签 <script type="text/javascript" ></script> 弥补有些浏览器CSS 加载缺陷
2head 标签之间缺少 <link rel="shortcut icon" href="http://www.xxx.xxx.com/favicon.ico" /> 造成服务器404 的错误请求
3head 标签之间缺少 <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" /> IE8 , 使用 IE7 兼容样式
4head标签中的内容,请增加标签 <meta http-equiv="Content-Language" content="zh-CN" />  
5html头部分,属性请规范化 <html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN" xml:lang="zh-CN">  
   
 登录首页优化(目前有12站内请求,6个站外请求)原因
1外链CSS 内容,直接放到 header 之间 <style type="text/css"> …</style> 尽可能减少额外的请求,服务器在密集响应的时候,很可能对一个不到1K的js做很长时间的相应
2js部分,除了公共的 js 库外,只对 login.jsp 产生作用的 js 外联文件,请直接写在页面内的尾部,
例如:
...<script type="text/javascript"> ..<script>...</body>
3尽可能合并小的js 到有个 js 文件
   
 SEO 
   
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值