构建高可用高性能网站的建议

转自:

http://www.iteye.com/news/30202


虽然零零碎碎了解些,但是总结的这么全面,还是收藏下,分享给各位看官!


优化了加载速度的网站不仅可以提高其搜索引擎的排名,同时也可以降低网站的跳出率,提高其转换率,还能提供更好的终端用户体验,这是当今基于Web环境取得成功的关键。 


构建高可用高性能网站的建议_第1张图片 

下面我将介绍几个优化网站加载网页速度的简单方法,一起来看一下。 

1.服务器响应时间  

即使网站已经格外优化,但是除非服务器响应时间非常快,否则就不会有什么大的效果。当涉及到提高网站的速度,服务器响应时间起着重要的作用。下面是一些提高服务器响应时间的小贴士。 
  • 有独立的服务器,而不是选择共享/托管服务器。
  • 提高Web服务器的质量。
  • 移除不必要的插件,只有那些必要的插件,才需要一直保持启用状态。

2.浏览器缓存  

浏览器缓存可以减少HTTP请求,从而反过来提高网站的加载速度。下面就是如何利用浏览器缓存的代码示例: 
Java代码 
  1.   
  2. ExpiresActive On  
  3. ExpiresByType image/jpg "access 1 year"  
  4. ExpiresByType image/jpeg "access 1 year"  
  5. ExpiresByType image/gif "access 1 year"  
  6. ExpiresByType image/png "access 1 year"  
  7. ExpiresByType text/css "access 1 month"  
  8. ExpiresByType text/html "access 1 month"  
  9. ExpiresByType application/pdf "access 1 month"  
  10. ExpiresByType text/x-javascript "access 1 month"  
  11. ExpiresByType application/x-shockwave-flash "access 1 month"  
  12. ExpiresByType image/x-icon "access 1 year"  
  13. ExpiresDefault "access 1 month"  
  14.   

注意:如果过期时间与文件挂钩,而此时文件中的内容需要更改的话,那必须先重命名文件,以便浏览器可以获取新添加的代码。 

3.gzip压缩  

gzip压缩是一个压缩实用程序,我们可以用它来快速加载网站。它的工作原理是在发送HTML和CSS文件到互联网浏览器之前,先压缩文件大小。允许mod_defalte模块启用Gzip压缩,下面是如何使用它的代码示例: 
Java代码 
  1.   
  2. # Compress HTML, CSS, JavaScript, Text, XML  
  3. AddOutputFilterByType DEFLATE application/javascript  
  4. AddOutputFilterByType DEFLATE application/xhtml+xml  
  5. AddOutputFilterByType DEFLATE application/xml  
  6. AddOutputFilterByType DEFLATE text/css  
  7. AddOutputFilterByType DEFLATE text/html  
  8. AddOutputFilterByType DEFLATE text/javascript  
  9. AddOutputFilterByType DEFLATE text/plain  
  10. AddOutputFilterByType DEFLATE text/xml  
  11. # Remove browser bugs (only needed for really old browsers)  
  12. BrowserMatch ^Mozilla/4 gzip-only-text/html  
  13. BrowserMatch ^Mozilla/4\.0[678] no-gzip  
  14. BrowserMatch \bMSIE !no-gzip !gzip-only-text/html  
  15. Header append Vary User-Agent  
  16.   

4.异步脚本  

还有一个可以提高网站页面速度的超棒选择就是异步加载脚本。如此一来网页负载就并不必依赖于这些异步脚本,网站访问者也不再需要不得不按捺下性子,等待所有的脚本加载完之后才能呈现页面。在异步模式中,脚本是在后台下载的。通常,我们会将第三方脚本作为异步脚本,因为下载这些脚本时常会让网站速度变得非常慢。
Css代码 
  1. "http://www.yoursite.com/script.js">  

5.内容分发网络(CDN)  

内容分发网络(CDN)是位于不同地理位置的服务器组成的网络。每个服务器都拥有所有网站的文件副本。要是有网站访问者请求文件和网页时,就可以直接从就近的网站服务器发送过来(也可以是从负载最小的服务器)。 

6.优化JavaScript、HTML和CSS  

优化JavaScript和CSS也可以提高一个网站的网页速度,而且这个方法非常简单。优化JavaScript、HTML和CSS就是删除所有不必要的空格和注释,从而减小文件大小。下面是一些最小化JavaScript和CSS的流行工具,非常有用。 

  • CSS Minifier
  • Avivo
  • HTML Compressor

7.置于顶部的样式表和底部的脚本  

将样式表放在顶部有助网站的迅速加载,因为这样可以使得网页渐进式呈现。一般地,所有的互联网浏览器都支持在给定时间内并行下载两个组件(图像、样式和脚本)。但是通常而言,霸道的脚本会在并行下载时会阻止其他的下载,直到脚本下载完毕。 
8.避免阻塞型的JavaScript和CSS  

在浏览器呈现网页之前,它首先需要通过解析HTML标记语言来构建一个DOM树。在此过程中,如果遇到了脚本,此过程就会中止,转而先执行脚本,完了才会继续原先的活动。因此建议避免阻塞型的JavaScript,尤其是外部脚本。 

阻塞型JavaScript还会导致网站的延迟。所以不妨推迟加载那些不重要的JavaScript,或者采用异步加载的方式。另一种选择是将这些HTML代码内嵌到网站上,同时需要确保CSS的优化。 

9.JavaScript的延迟解析  

为了加载网页,浏览器必须解析所有的

你可能感兴趣的:(构建高可用高性能网站的建议)