佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 高性能WEB開發(fā) 為什么要減少請求數(shù),如何減少請求數(shù)!

高性能WEB開發(fā) 為什么要減少請求數(shù),如何減少請求數(shù)!

熱門標(biāo)簽:服務(wù)器配置 網(wǎng)站文章發(fā)布 銀行業(yè)務(wù) 檢查注冊表項(xiàng) 鐵路電話系統(tǒng) 美圖手機(jī) 呼叫中心市場需求 智能手機(jī)
http請求頭的數(shù)據(jù)量

我們先分析下請求頭,看看每次請求都帶了那些額外的數(shù)據(jù).下面是監(jiān)控的google的請求頭

Host www.google.com.hk
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 text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
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


返回的response head

Date Sat, 17 Apr 2010 08:18:18 GMT
Expires -1
Cache-Control private, max-age=0
Content-Type text/html; charset=UTF-8
Set-Cookie PREF=ID=b94a24e8e90a0f50:NW=1:TM=1271492298:LM=1271492298:S=JH7CxsIx48Zoo8Nn; expires=Mon, 16-Apr-2012 08:18:18 GMT; path=/; domain=.google.com.hk NID=33=EJVyLQBv2CSgpXQTq8DLIT2JQ4aCAE9YKkU2x-h4hVw_ATrGx7njA69UUBMbzVHVnkAOe_jlGGzOoXhQACSFDP1i53C8hWjRTJd0vYtRNWhGYGv491mwbngkT6LCYbvg; expires=Sun, 17-Oct-2010 08:18:18 GMT; path=/; domain=.google.com.hk; HttpOnly
Content-Encoding gzip
Server gws

Content-Length 4344


這里發(fā)送的請求頭的大小大概420 bytes,返回的請求頭大概 600 bytes。

可見每次請求都會帶上一些額外的信息進(jìn)行傳輸(這次請求中還沒有帶cookie),當(dāng)請求的資源很小,比如1個(gè)不到1k的圖標(biāo),可能request帶的數(shù)據(jù)比實(shí)際圖標(biāo)的數(shù)據(jù)量還大。

所以當(dāng)請求越多的時(shí)候,在網(wǎng)絡(luò)上傳輸?shù)臄?shù)據(jù)自然就多,傳輸速度自然就慢了。

其實(shí)request自帶的數(shù)據(jù)量還是小問題,畢竟request能帶的數(shù)據(jù)量還是有限的。

http連接的開銷


相比request頭部多余的數(shù)據(jù),http連接的開銷則更加嚴(yán)重。先看看從用戶輸入1個(gè)URL到下載內(nèi)容到客戶端需要經(jīng)過哪些階段:

1. 域名解析
2. 開啟TCP連接
3. 發(fā)送請求
4. 等待(主要包括網(wǎng)絡(luò)延遲和服務(wù)器處理時(shí)間)
5. 下載資源


可能很多人認(rèn)為每次請求大部分時(shí)間都花在下載資源上,讓我們看看blogjava資源下載瀑布圖(每種顏色代表的階段與上面5個(gè)階段對應(yīng)):

看了上圖你可能驚訝,花費(fèi)在等待階段的時(shí)間比實(shí)際下載的時(shí)間要多的多,上圖告訴我們:
1. 每次請求花費(fèi)的大部分時(shí)間在其他階段,而不是在下載資源階段
2. 再小的資源照樣會花費(fèi)很多時(shí)間在其他階段,只是下載階段會比較短(見上圖的第6個(gè)資源,才284Byte)。

正對上面提到的2種情況,我們應(yīng)該要怎么進(jìn)行優(yōu)化了?減少請求數(shù)來減少其他階段的花銷和網(wǎng)絡(luò)中傳輸?shù)臄?shù)據(jù)。

如何減少請求數(shù)

1、合并文件
合并文件就是把很多JS文件合并成1個(gè)文件,很多CSS文件合并成1個(gè)文件,這種方法應(yīng)該很多人用到過,這里不做詳細(xì)介紹,
只推薦1個(gè)合并的工具:yuiCompressor 這個(gè)工具yahoo提供的。 http://developer.yahoo.com/yui/compressor/

2、合并圖片
這是利用css sprite,通過控制背景圖片的位置來顯示不同的圖片。這種技術(shù)也是大家都用過的,不做詳細(xì)介紹,推薦1個(gè)在線合并圖片的網(wǎng)站:http://csssprites.com/

3、把JS、CSS合并到1個(gè)文件
上面第1種方法說的只是把幾個(gè)JS文件合并成1個(gè)JS文件,幾個(gè)CSS文件合并成1個(gè)CSS文件,哪如何把CSS和JS都合并到1個(gè)文件中,見我的另1篇文章:
http://www.blogjava.net/BearRui/archive/2010/04/18/combin_css_js.html

4、使用Image maps
Image maps 是把多個(gè)圖片合并成1個(gè)圖片,然后使用html中的map>標(biāo)簽連接圖片,并實(shí)現(xiàn)點(diǎn)擊圖片不同的區(qū)域執(zhí)行不同的動作,image map在導(dǎo)航條中比較容易使用到。
image map的使用方法見: http://www.w3.org/TR/html401/struct/objects.html#h-13.6

5、data嵌入圖片
這種方法把圖片進(jìn)行編碼直接嵌入到html中進(jìn)行使用,以減少HTTP請求,但這個(gè)會增加HTML頁面的大小,而且這樣嵌入的圖片不能緩存。見下面這個(gè)圖片:


上面的圖片就是把圖片進(jìn)行base64編碼后使用data:嵌入到html中,代碼如下(后面的省略了,大家可以查看源代碼看):
IMG SRC="data:image/gif;base64,/9j/4AAQSkZJRgABAQEAYABgAAD/4QAWRXhpZgAASUkqAAgAA......">


其中g(shù)oogle的視頻搜索中,搜索出來的視頻縮略圖就都是使用嵌入的圖片的,見下圖:



以上幾種方法在都有利有弊,在不同情況下可以選擇不同的使用方式,比如使用data嵌入圖片雖然減少了請求數(shù),但會增加頁面大小。


所以微軟的bing搜索在用戶第一次訪問的時(shí)候使用data嵌入圖片,然后后臺懶加載真真的圖片,以后訪問就直接使用緩存的圖片,而不使用data。

[聲明] 轉(zhuǎn)載請注明出處:http://www.blogjava.net/BearRui/。 禁止商用!
您可能感興趣的文章:
  • WEB高性能開發(fā)之瘋狂的HTML壓縮
  • web高性能開發(fā)系列隨筆 BearRui(AK-47)版
  • 高性能WEB開發(fā) flush讓頁面分塊,逐步呈現(xiàn) flush讓頁面分塊,逐步呈現(xiàn)
  • 高性能WEB開發(fā) 頁面呈現(xiàn)、重繪、回流。
  • 高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理
  • 高性能WEB開發(fā)(5) 減少請求,響應(yīng)的數(shù)據(jù)量
  • 高性能web開發(fā) 如何加載JS,JS應(yīng)該放在什么位置?
  • 高性能WEB開發(fā) 圖片壓縮篇
  • 高性能WEB開發(fā) web性能測試工具推薦
  • 高性能WEB開發(fā) nginx HTTP服務(wù)器篇
  • 編寫高性能的JavaScript 腳本的加載與執(zhí)行
  • 了解CSS的查找匹配原理,讓CSS更簡潔、高效

標(biāo)簽:紅河 長治 沈陽 樂山 河南 上海 新疆 滄州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《高性能WEB開發(fā) 為什么要減少請求數(shù),如何減少請求數(shù)!》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    平湖市| 图片| 湘西| 淮北市| 绍兴县| 左云县| 新河县| 靖远县| 黎平县| 闸北区| 墨江| 肇东市| 长白| 南岸区| 宽甸| 广宁县| 乡宁县| 莒南县| 宜宾县| 新巴尔虎左旗| 富民县| 荣成市| 兴文县| 剑川县| 巩留县| 扶绥县| 昌乐县| 泰宁县| 静海县| 会宁县| 凤翔县| 从化市| 雷州市| 定州市| 称多县| 麻江县| 维西| 宝山区| 长岭县| 瑞昌市| 保亭|