网站优化之——高性能网站建设指南

网站优化之——高性能网站建设指南

不考虑带宽大小,不考虑服务器性能如何,如何保证网站从服务器到用户浏览器这个过程是最快的,打开一个网站之前的用户体验是最好的呢。Steve Souders的高性能网站建设指南这本书当中给我们建议了以下几种方法:

1.减少HTTP请求
2.使用内容分发网络(传说中的CDN服务)
3.添加Expires头
4.压缩组件
5.将样式表文件放在顶部
6.将脚本文件放在底部
7.避免CSS表达式
8.CSS样式表文件和JS脚本文件使用外链的方式引入
9.减少DNS查找
10.精简Javascript
11.避免重定向
12.移除重复脚本
13.配置ETag
14.是AJAX可缓存

作者的意图是上面的14条建议都是经过各大网站测试的数据当中所总结的,我们暂且不论这些建议是否真正的有效,先来表表这14条建议都是什么含义,如何做到这14条建议。说白了就是如果我们想用这14条建议到我们的项目当中,我们需要遵守些什么,什么要做,什么不要做,怎么做的问题。

第一条:减少HTTP请求

网站性能优化,就是优化网站打开的速度了。把这一条放在第一的位置,肯定因为这家伙非常的耗用资源。你说啥?啥是HTTP?如果不明白啥是HTTP,尊驾请异步这里。HTTP_超文本传送协议定义了浏览器(即万维网客户进程)怎样向万维网服务器请求万维网文档,以及服务器怎样把文档传送给浏览器。要明白为什么说HTTP请求耗用资源,就得稍微了解下HTTP请求。
一次完整的HTTP请求主要包括如下步骤:1、建立TCP连接2、浏览器向WEB服务器发送请求命令3、WEB浏览器发送请求头信息4、WEB服务器应答5、WEB服务器发送应答头信息6、WEB服务器向浏览器发送数据7、WEB服务器关闭TCP连接。每一个步骤都需要耗费时间来完成,比如步骤3,就相当于平常我们上传东西,步骤6,相当于我们从网上下载,这些步骤虽然很快,但还是会耗费时间去干这些事,而且每次HTTP请求都会重复做上面的1~7这写步骤,如果页面当中HTTP请求的数量过多,就会耗用大量的时间,导致网站加载速度过慢。网页当中的图片,样式文件,脚本文件和视频媒介文件都会有HTTP请求的发生,当你的网站当中图片的数量越多,你的网站打开的速度就会越慢。像百度图片这种只好选用其它的方式来优化网站的速度,例如图片延迟加载。总的来说,尽量减少我们网页当中的HTTP请求就对了。那怎么做呢?上面也说了,页面当中的图片,样式、脚本和视频文件会进行HTTP请求,我们主要就是针对图片、样式、脚本、Flash视频这几个内容进行优化。

第一步:使用图片地图,HTML当中的标签<map><area ....></map>
第二步:尽量把网站中使用的图片,作为标签的背景写到CSS样式文件当中。当作为背景的图片数量越来越 多的时候,就使用CSS Sprites技术,把多个图片合并成一张图片。
第三步:通过使用data:url在页面当中包含图片但无需额外的HTTP请求(低版本的IE不支持),比如我门见到过的Base64位图片
第四步:就是尽可能的合并CSS和JS文件

第二条:使用内容发布网络

什么是内容发布网络?其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快、更稳定。如果用户A身在中国,网站B的服务器在美国,网站C的服务器在中国,那么理论上用户A访问网站C的速度要比访问B的速度快。因为A用户和C网站在距离上更近,网络数据传输的距离近,时间上就会短。内容发布网络就是分布在多个不同地理位置的WEB服务器,用于更加有效的向用户发布内容。
例如M用户请求了G网站,G网站上的一个文件F存放在内容分发网络的某一个服务器上面。当你的网站W引用文件F的时候,也是使用改内容发布网络,当M用户访问你的网站W的时候,它因为已经在访问G网站的时候下载过F文件了,所以在访问你的网站W的时候,就不用重新下载该文件了,直接从用户本地的缓存中读取。如果该文件F之前没有被缓存过,就会从靠近用户M距离最近的那个内容发布网络节点下载该文件。

第三条:添加Expires头

添加一个时间足够久的Expires头,用来缓存从服务器上请求的文件。
假如你定义了如下:

Expires: Thu, 15 Apr 2017 20:00:00 GMT

这是一个有效期非常长的Expires头,它告诉浏览器在2017年4月15日之前,都是用这个请求过的缓存文件。这样做就将HTTP请求的数量减少一个。
Expires头使用一个特定的时间,它要求服务器端和客户端的时钟严格同步。
换另外一种方式,Cache-Control使用max-age指令制定组件被缓存多久。让人值得庆幸的是有些浏览器默认都设置了这些内容,例如IIS服务器上。
添加Expires头的真正意义其实还是为了减少HTTP请求。

第四条:压缩组件

前端:

通过对CSS样式文件和JS脚本文件的内容压缩,图片压缩,如果是PNG格式的图片压缩,推荐使用TinyPNG。

服务端:

启用GZIP编码来压缩HTTP响应包的大小。通过HTTP请求中的Accept-Encoding头来标识对压缩的支持。
Accept-Encoding:gzip,deflate
IIS服务器默认情况是开启文件压缩的。
内容压缩的主要意义是减少HTTP请求响应的大小来减少响应时间。

第五条:将样式表放在顶部

HTML当中的内容是至上而下加载的,样式文件放在顶部,在加载HTML文档的时候,同时也在加载样式文件,这样页面会一边加载一边让浏览器渲染已经加载好的内容,也就是“逐步呈现”我们的网页内容。

将样式表文件放在文档底部会导致在浏览器中阻止内容逐步呈现。把样式文件放在顶部对整个页面的加载时间并没有减少,它影响的是浏览器对我们页面上内容加载的反映。

一点一点的加载让用户看到我们的页面,比加载完所有内容之后再把页面展示给我们的用户,两种方式在时间上并没有什么差别,但去能给用户不一样的感觉。

第六条:将脚本放在底部

加载脚本会阻止页面逐步呈现。当浏览器加载到一段JS脚本的时候,它会等待这一段脚本解析完成之后,再继续加载下面的内容。如果解析脚本花费的时间为1s种,那么用户就要等待1s之后才能看到页面一点一点的加载。阻止逐步呈现就意味着等待,就会影响用户的体验。

第七条:避免CSS表达式

使用CSS表达式就是使用expression来设置页面的某些样式。这种方法现在使用的人应该不多了,但我们了解下总没有什么不好的。
为什么使用表达式不好?因为表达式计算的频率太高,浪费浏览的资源。
加入有个下面的CSS规则:

<code>
p{
width:expression(setCntr(),document.body.clientWidth<600?"600px":"auto");
}
</code>

setCntr()函数增加一个全局变量的值并将这个值应用到一个页面元素上面。如果页面中有个10个段落(p)。加载整个页面会执行CSS表达式10次。如果用户改变了页面窗口的大小,滚动鼠标,该CSS表达式都会被执行10次。这样毫无意义的计算,浪费浏览器的资源是很可怕的。如果你在一个页面当中应用过多的CSS表达式,就会照成浏览器崩溃。

第八条:引用外部的JS和CSS

首先我们思考如下一个问题:
情况一:HTML页面大小有50K,CSS样式文件大小有20K,脚本JS文件有30K。
情况二:页面B包含样式CSS和脚本JS,大小是90K

分布测试两种情况,我们会发现情况二要比情况一快30%~50%,因为情况一需要承担多个HTTP请求带来的开销。
的确内联所需要的开销时间会短些;但是,如果放入外部文件中,有下面的好处:
1.样式文件和JS文件就有机会被浏览器缓存起来。
2.能够被项目当中的其它页面重用。
这样同一个HTML文件,不增加HTTP请求数量的基础上,肯定体积大所需要的开销会大些。
维护性上,如果把样式文件CSS和脚本文件JS统统放在页面HTML当中,我们能够想想是怎么一种混乱的情况吗?

第九条:减少DNS查找

当浏览器与Web服务器建立连接时,它需要进行DNS解析,将域名解析为IP地址。然而,一旦客户端需要执行DNS lookup时,等待时间将会取决于域名服务器的有效响应的速度。

第十条:精简Javascript

这里比较不好把握,牵扯到编写JS脚本的一些内容。例如:避免使用过多的全局遍历,避免过多的DOM操作,缓存查找到的DOM元素。然后就是使用Grunt这种工具对文件进行压缩。

第十一条:避免重定向

这个地方主要说的是后台代码的重定向,我这里不多说

第十二条:移除重复脚本

重复脚本对网站性能照成的损伤有两个方面:
1、增加不必要的HTTP请求
2、执行javascript所浪费的时间

第十三条:配置ETag

这一条是为了防止缓存不起作用进行的配置,属于后台方面的内容。
最终目的:缓存内容减少HTTP请求。

第十四条:使Ajax可缓存

使Ajax可缓存的前提是保证你的数据是不经常变化的,如果发生变化就重新从服务器请求新的数据,我们使用一个长久的Expires头来缓存Ajax请求的内容。

关于Ajax,我建议通过Ajax请求的内容仅包含必须从服务端返回的数据信息,HTML结构部分则缓存到HTML页面当中,然后通过模版解析,把所通过ajax请求的内容展示出来,因为目前浏览器端的运算速度越来越快了,所以现在完全可以这样做。

结束语

网站性能优化,我的理解就是优化一个网站打开的速度,也就是怎么样让用户体验到飞一般的感觉。
网站优化包括前端优化和后台优化,这本书并没有按照前后端这样来分别讲解网站优化。
下面再针对前端方面说几个性能优化的方面:

1.了解Repaint和Reflow,减少页面reflow,像document.write,document.getElementById("xx").style.xx=''这些,都会reflow页面。
2.减少DOM操作,还有上面说到的,把查找到的DOM进行缓存。
3.使用json数据交换格式
4.语义化HTML

总的来说优化的最终目的就是:减少HTTP请求,压缩HTTP请求响应的文件大小,尽量缩短用户访问网站所花费的时间。
如果您看到了这里,真的非常感谢。
文章当中有不准确或者不恰当的地方,烦请您指正留情,同时大家也有什么好的优化方式也请留言,到时会补充到这篇文章当中,先在此谢谢了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容