成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

高性能WEB開發之減少請求、響應的數據量

開發 前端
這次說說如何減少請求、響應的數據量(即在網絡中傳輸的數據量),減少傳輸的數據量不僅僅可以加快頁面加載速度,更可以節約服務器帶寬,為你剩不少錢(好像很多機房托管都是按流量算錢的).

上一篇中我們說到了 如何減少請求數,這次說說如何減少請求、響應的數據量(即在網絡中傳輸的數據量),減少傳輸的數據量不僅僅可以加快頁面加載速度,更可以節約服務器帶寬,為你剩不少錢(好像很多機房托管都是按流量算錢的)。

GZIP壓縮

gzip是目前所有瀏覽器都支持的一種壓縮格式,IE6需要SP1及以上才支持(別說你還在用IE5,~_~)。gzip可以說是最方便而且也是***減少響應數據量的1種方法。

說它方便,是因為你不需要為它寫任何額外的代碼,只需要在http服務器上加上配置都行了,現在主流的http服務器都支持gzip,各種服務器的配置這里就不一一介紹(其實是我不知道怎么配),

nginx的配置可以參考我這篇文章:www.blogjava.net/BearRui/archive/2010/01/29/web_performance_server.html

我們先看看gzip的壓縮比率能達到多少,這里用jquery 1.4.2的min和src2個版本進行測試,使用nginx服務器,gzip壓縮級別使用的是4:

高性能WEB開發- 減少請求,響應的數據量

注意看上圖的紅色部分,jquery src文件在啟用gzip后大小減少了70%

高性能WEB開發- 減少請求,響應的數據量

這張圖片可以看出就算是已經壓縮過min.js在啟用gzip后大小也減少了65%。

別對圖片啟用gzip

在知道了gzip強大的壓縮能力后,你是否想對服務器上的所有文件啟用gzip了,先讓我們看看圖片中啟用gzip后會是什么情況。

高性能WEB開發- 減少請求,響應的數據量

hoho,1個gif圖片經過gzip壓縮后反而變大了???這是因為圖片本來就是一種壓縮格式,gzip不能再進行壓縮,反而會添加1些額外的頭部信息,所以圖片會變大。

在測試過程中,發現jpg的圖片經過gzip壓縮后會變小,不知道為何,可能跟圖片壓縮方式有關。不過壓縮比率也比較小,所以就算是jpg,建議也不要開啟gzip壓縮。

比較適合啟用gzip壓縮的文件有如下這些:

1. javascript

2. CSS

3. HTML,xml

4、plain text

別亂用cookie

現在幾乎沒有哪個網站不使用cookie了,可是該怎么使用cookie比較合適了,cookie有幾個重要的屬性:path(路徑),domain(域),expires(過期時間)。瀏覽器就是根據這3個屬性來判斷在發送請求的時候是否需要帶上這個cookie。

cookie使用***的方式,就是當請求的資源需要cookie的時候才帶上該cookie。其他任何請求都不帶上cookie。但事實上很多人在使用cookie的時候已經習慣性的設置成:path=/ domain=.domain.com。這樣的結果就是不管任何請求都會帶上cookie,就算你是請求的圖片(img.domain.com)、靜態資源服務器(res.domain.com)這些根本不需要cookie的資源,瀏覽器照樣會帶上這些沒用的cookie。咱們一起來看現實中的1個列子,博客園(www.cnblogs.com):

先看看博客園的cookie是怎么設置的,下面是firefox查看博客園cookie的截圖:

高性能WEB開發- 減少請求,響應的數據量

cnblogs總共有5個cookie值,而且全部設置都是 path=/ domain=.cnblogs.com。知道了cookie的設置后,我們再來監控下博客園首頁的請求,監控的統計信息如下:

總請求數:39(其中圖片22個,JS7個,css2個)。

其中js、css、image 主要來自3個靜態資源服務器: common.cnblogs.com , pic.cnblogs.com ,static.cnblogs.com

再看其中1個請求圖片(http://static.cnblogs.com/images/a4/banner_job.gif)的請求頭:

Host static.cnblogs.com

User-Agent Mozilla/5.0 (Windows; U; Windows NT 5.2; en-US; rv:1.9.2.3) Gecko/20100401 Firefox/3.6.3 GTBDFff GTB7.0

Accept image/png,image/*;q=0.8,*/*;q=0.5

Accept-Language zh-cn,en-us;q=0.7,en;q=0.3

Accept-Encoding gzip,deflate

Accept-Charset ISO-8859-1,utf-8;q=0.7,*;q=0.7

Keep-Alive 115

Proxy-Connection keep-alive

Referer http://www.cnblogs.com/

Cookie __gads=ID=a15d7cb5c3413e56:T=1272278620:S=ALNI_MZNMr6_d_PCjgkJNJeEQXkmZ3bxTQ; __utma=226521935.1697566422.1272278366.1272278366.1272278366.1; __utmb=226521935.2.10.1272278366; __utmc=226521935; __utmz=226521935.1272278367.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none)

我們發現在請求banner_job.gif這個圖片的時候,瀏覽器把cnblogs.com的所有cookie都帶上了(其他圖片的請求都是一樣的),我估計博客園在處理圖片的時候應該不需要用到cookie吧?也許你認為這幾個cookie的大小只有300個字節左右,無所謂啦。

我們做個簡單的計算,假設博客園每天有50W個PV(實際情況應該不止吧),每次PV大概有15次請求靜態資源,15*500000*300/1024/1024=2145M。也就說這幾個cookie每天大概會耗費博客園2G的帶寬。當然這種簡單的計算方式肯定會有偏差,畢竟我們還沒把靜態資源緩存考慮進去。但是個人覺得要是博客園要是把cookie的domain設置為www.cnblogs.com會更好一些。

妙用204狀態

http中200,404,500狀態大家都很清楚,但204狀態大家可能用的比較少,204狀態是指服務器成功處理了客戶端請求,但服務器無返回內容。204是HTTP中數據量最少的響應狀態,204的響應中沒有body,而且Content-Length=0。很多人在使用ajax提交一些數據給服務器,而不需要服務器返回的時候,常常在服務端使用下面的代碼:response.getWriter().print(""),這是返回1個空白的頁面,是1個200請求。它還是有body,而且Content-Length不會等于0。其實這個時候你完全可以直接返回1個204狀態(response.setStatus(204))。204在一些網站分析的代碼中最常用到,只需要把客戶端的一些信息提交給服務器就完事,讓我們看看google首頁的1個204響應,google首頁的***1個請求返回的就是204狀態,但這個請求是干嘛用的就沒猜出來了:
 

高性能WEB開發- 減少請求,響應的數據量 

系列文章:

高性能WEB開發之如何減少請求數

高性能WEB開發之如何加載JavaScript

高性能WEB開發之圖片篇

高性能WEB開發之Web性能測試工具推薦

高性能WEB開發之HTTP服務器

責任編輯:陳貽新 來源: BearRui的博客
相關推薦

2011-04-21 09:59:48

WEBjavascript

2013-06-19 09:20:53

Web開發Web性能優化高性能

2011-04-18 10:16:30

WEB高性能

2011-04-07 13:53:25

Web工具

2011-04-27 10:57:29

高性能web開發

2011-10-18 13:58:32

高性能web

2011-04-19 11:06:03

JavaScriptweb

2011-04-22 09:54:37

CSSjavascript

2011-04-07 13:39:24

WebHTTP

2011-06-14 09:27:43

高性能WEB開發

2013-09-10 16:16:19

移動網站性能優化移動web

2011-04-25 10:11:57

高性能web開發

2011-04-28 09:40:26

flush高性能Web開發

2011-03-03 10:32:07

Mongodb億級數據量

2016-08-23 14:37:21

2009-07-30 10:28:56

Web高性能開發

2016-11-28 09:19:27

2013-08-16 14:43:14

高性能移動Web移動Web站點移動Web

2015-03-09 10:40:44

MySQL大量數據插入

2022-10-14 17:24:35

MySQLSQL優化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 韩日一区二区三区 | 97久久精品午夜一区二区 | 国产一区二区电影 | 欧美一区二区三区在线 | 欧美一区精品 | 欧美亚洲国产精品 | 蜜桃精品噜噜噜成人av | 成在线人视频免费视频 | 国产成人精品一区二区在线 | 中文精品一区二区 | 免费欧美| 日韩视频在线播放 | 色久电影 | 九九综合九九 | av国产精品毛片一区二区小说 | 久色视频在线 | 9191在线播放 | 欧美一级二级三级视频 | 久久久久亚洲av毛片大全 | 天天插天天操 | 精一区二区 | xxxxx免费视频 | 伦理片97| 成人精品一区亚洲午夜久久久 | 亚洲一区二区三区在线免费 | av中文字幕在线 | 男女羞羞视频在线 | 日韩免费av | 精品国产一区二区三区性色av | 91青青草视频| 国产乱精品一区二区三区 | 亚洲免费网址 | 一区二区三区精品 | 亚洲大片 | 久久久成人动漫 | 久久极品 | 亚洲一区中文字幕 | 欧美国产精品 | 夜夜操天天干 | 日韩亚洲一区二区 | 欧美精品成人一区二区三区四区 |