IIS的內容緩存過期機制實踐 有效提高站點性能
更新時間:2012年01月09日 20:01:53 作者:
目前,隨著網(wǎng)頁內容越來越絢爛,訪問速度卻令人越來越不滿。實踐證明,正確設置Http Response Header中的Expires頭將有助于提高網(wǎng)頁訪問速度
我們的網(wǎng)站中往往包含大量的頁面組件,比如圖片、樣式表文件、JS腳本文件和Flash動畫。這些組件的變化頻率非常低,尤其是那些構成網(wǎng)站基本框架的組件,
幾乎不會發(fā)生變化。我們可以將這些變化率很低的組件看作靜態(tài)內容,利用IIS的內容過期機制和瀏覽器的本地緩存機制將它們在訪問者的電腦硬盤中保存一段時間。
當訪問者訪問你的網(wǎng)站時,如果這些存在本地的靜態(tài)內容沒有過期,瀏覽器會從本地硬盤中裝載,而不去向服務器發(fā)出請求。
如果你使用Fiddler這樣的工具跟蹤網(wǎng)頁訪問,你會清楚地看到雖然只是訪問一個頁面,但是發(fā)出的Http請求和應答卻不止一個。網(wǎng)頁中的每張圖片,每個
JS腳本文件,每個CSS文件,都會引發(fā)一次請求和應答。因此如果想讓網(wǎng)頁的訪問速度快起來,減少Http的請求數(shù)量,降低從服務器下載內容的次數(shù)是有效途徑。
而使用了內容過期機制后可以就實現(xiàn)這樣的目的,這就是使用內容過期機制的意義。
大多數(shù)的Web開發(fā)者都玩過IIS 6或IIS 7,但是又有多少人仔細觀察過HTTP Headers或HTTP Response Headers標簽中的內容呢?此處我以IIS 6 為例,
默認情況下此標簽中的界面如下圖:

此時,如果向該網(wǎng)站的一個網(wǎng)頁發(fā)出請求,該網(wǎng)頁中包含了一張圖片的鏈接,那么在獲取到該網(wǎng)頁的HTML文檔之后,瀏覽器會繼續(xù)對這張圖片發(fā)出請求,該請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 ok (表示服務器找到了此圖片并正確響應)
Date:Thu, 04 Feb 2010 08:25:38 GMT (響應的時間,格林尼治時間)
Last-Modified:Wed, 03 Jan 2009 01:55:06 GMT(圖片最后被修改的時間,格林尼治時間)
這張圖片會被瀏覽器保存在本地硬盤的IE臨時文件夾中。使用同一個瀏覽器窗口在同一個會話中再次訪問到這個頁面,
則頁面中的組件都不再重新請求。
當在這臺機器上打開另一個瀏覽器窗口(另一個會話)又一次訪問此頁面時,由于這張圖已經(jīng)在本地保存了,但是瀏覽器
剛才的響應中并沒有規(guī)定內容的過期機制,因此瀏覽器仍會向服務器發(fā)出一次請求:
If-Modified-Since: Wed, 03 Jan 2009 01:55:06 GMT (詢問服務器,我本地這張圖片的最后修改時間是這個,在此時間之后你那有沒有更新的版本?)
If-None-Matched: "abdkfkdkdkdjkjkfkfd" (這是一段ETag編碼,是服務器端給該組件的唯一標示)
服務器收到請求后檢查被請求的圖片,發(fā)現(xiàn)它的最近修改時間還是Wed, 03 Jan 2009 01:55:06 GMT ,于是響應請求:
HTTP/1.1 304 Not Modified (請求的圖片找到了,并且沒有被改變過)
Date:Thu, 04 Feb 2010 08:25:38 GMT (響應的時間)
瀏覽器收到這個響應就知道它可以放心地使用本地存儲的這張圖片了,不必再從服務器重新下載該組件。
由此可見,IIS Http Headers標簽的默認設置是不禁止瀏覽器緩存的,但是也沒有告訴組件保存過期的時間,因此瀏覽器將組件保存在本地后,
每次訪問都會詢問服務器此組件是否過期,如果沒過期則使用本地保存的內容,否則從服務器下載內容。 可以看出它只減少了從服務器下載內容的次數(shù),
并沒有減少向服務器發(fā)出請求的次數(shù),請求和響應依然耗費了時間。
在IIS中定位到網(wǎng)站存放圖片的文件夾,然后打開屬性窗口,在HTTP Headers中做出如下選擇,要求組件的過期時間為本次請求后1天,也就是在本地緩存86400秒。

打開瀏覽器,首次訪問該網(wǎng)站的一個網(wǎng)頁,該網(wǎng)頁中包含一張圖片的鏈接,于是該圖片請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 OK (表示服務器找到了此圖片并正確響應)
Cache-Control: max-age=86400 (從本次請求時間算起,允許該圖片在本地緩存86400秒)
Date: Sat, 14 May 2011 08:09:29 GMT (響應的時間,格林尼治時間)
于是,只要是在1天之內,使用本機的瀏覽器打開這個網(wǎng)頁,都不會再對這張圖片發(fā)出請求,而是直接使用本地緩存中的這張圖片??梢姡瑴p少了不必要的HTTP請求,
提高了網(wǎng)頁的響應速度。
很多網(wǎng)站框架性的組件都是長期不變的,因此我們可以設置更長的過期時間,如下所示:

打開瀏覽器,首次訪問該網(wǎng)站的一個網(wǎng)頁,該網(wǎng)頁中包含一張圖片的鏈接,于是該圖片請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 OK (表示服務器找到了此圖片并正確響應)
Date: Sat, 14 May 2011 08:50:12 GMT(響應的時間,格林尼治時間)
Expires: Mon, 23 May 2011 16:00:00 GMT (該圖片的本地緩存到2011年5月23日16點為止,格林尼治時間)
那么這意味著只要在5月23日16點之前,在本機上訪問該網(wǎng)頁,都不會再對此圖片發(fā)出請求。
有人擔心如果這樣設置過期機制,一旦對這些組件做了更新,訪問者將不能收到變化,那豈不是也很遺憾。其實這有兩方面的解決方式:
一方面是網(wǎng)站的開發(fā)方,應該對圖片,樣式表文件和JS文件的命名方式進行改進,比如在文件名上加入版本號,這樣你一旦修改了組件內容,
就應該使組件擁有新的名稱,于是瀏覽器會發(fā)現(xiàn)本地沒有對這個組件緩存過,自然就會發(fā)起請求。
另一方面,訪問者可以通過瀏覽器的刷新功能強制對網(wǎng)頁中的組件重新發(fā)起請求。即使設置了過期機制,瀏覽器的刷新功能仍然會對所有頁面組件
發(fā)出請求的。
總結,本文的目的就是闡釋瀏覽器本地緩存與Web服務器緩存過期機制之間的交互關系,以及如何通過這種方式達到對性能的提升。
根據(jù)《高性能網(wǎng)站建設指南》一書中的統(tǒng)計,從瀏覽器向一個網(wǎng)頁發(fā)出請求算起,獲得網(wǎng)頁的HTML文檔的時間只占整個頁面應答完成時間的
5%,而剩余的95%時間全部是在請求和下載頁面中的各個組件。因此減少對頁面中組件的請求和下載,有效地利用瀏覽器緩存機制是十分有意義的。
幾乎不會發(fā)生變化。我們可以將這些變化率很低的組件看作靜態(tài)內容,利用IIS的內容過期機制和瀏覽器的本地緩存機制將它們在訪問者的電腦硬盤中保存一段時間。
當訪問者訪問你的網(wǎng)站時,如果這些存在本地的靜態(tài)內容沒有過期,瀏覽器會從本地硬盤中裝載,而不去向服務器發(fā)出請求。
如果你使用Fiddler這樣的工具跟蹤網(wǎng)頁訪問,你會清楚地看到雖然只是訪問一個頁面,但是發(fā)出的Http請求和應答卻不止一個。網(wǎng)頁中的每張圖片,每個
JS腳本文件,每個CSS文件,都會引發(fā)一次請求和應答。因此如果想讓網(wǎng)頁的訪問速度快起來,減少Http的請求數(shù)量,降低從服務器下載內容的次數(shù)是有效途徑。
而使用了內容過期機制后可以就實現(xiàn)這樣的目的,這就是使用內容過期機制的意義。
大多數(shù)的Web開發(fā)者都玩過IIS 6或IIS 7,但是又有多少人仔細觀察過HTTP Headers或HTTP Response Headers標簽中的內容呢?此處我以IIS 6 為例,
默認情況下此標簽中的界面如下圖:

此時,如果向該網(wǎng)站的一個網(wǎng)頁發(fā)出請求,該網(wǎng)頁中包含了一張圖片的鏈接,那么在獲取到該網(wǎng)頁的HTML文檔之后,瀏覽器會繼續(xù)對這張圖片發(fā)出請求,該請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 ok (表示服務器找到了此圖片并正確響應)
Date:Thu, 04 Feb 2010 08:25:38 GMT (響應的時間,格林尼治時間)
Last-Modified:Wed, 03 Jan 2009 01:55:06 GMT(圖片最后被修改的時間,格林尼治時間)
這張圖片會被瀏覽器保存在本地硬盤的IE臨時文件夾中。使用同一個瀏覽器窗口在同一個會話中再次訪問到這個頁面,
則頁面中的組件都不再重新請求。
當在這臺機器上打開另一個瀏覽器窗口(另一個會話)又一次訪問此頁面時,由于這張圖已經(jīng)在本地保存了,但是瀏覽器
剛才的響應中并沒有規(guī)定內容的過期機制,因此瀏覽器仍會向服務器發(fā)出一次請求:
If-Modified-Since: Wed, 03 Jan 2009 01:55:06 GMT (詢問服務器,我本地這張圖片的最后修改時間是這個,在此時間之后你那有沒有更新的版本?)
If-None-Matched: "abdkfkdkdkdjkjkfkfd" (這是一段ETag編碼,是服務器端給該組件的唯一標示)
服務器收到請求后檢查被請求的圖片,發(fā)現(xiàn)它的最近修改時間還是Wed, 03 Jan 2009 01:55:06 GMT ,于是響應請求:
HTTP/1.1 304 Not Modified (請求的圖片找到了,并且沒有被改變過)
Date:Thu, 04 Feb 2010 08:25:38 GMT (響應的時間)
瀏覽器收到這個響應就知道它可以放心地使用本地存儲的這張圖片了,不必再從服務器重新下載該組件。
由此可見,IIS Http Headers標簽的默認設置是不禁止瀏覽器緩存的,但是也沒有告訴組件保存過期的時間,因此瀏覽器將組件保存在本地后,
每次訪問都會詢問服務器此組件是否過期,如果沒過期則使用本地保存的內容,否則從服務器下載內容。 可以看出它只減少了從服務器下載內容的次數(shù),
并沒有減少向服務器發(fā)出請求的次數(shù),請求和響應依然耗費了時間。
在IIS中定位到網(wǎng)站存放圖片的文件夾,然后打開屬性窗口,在HTTP Headers中做出如下選擇,要求組件的過期時間為本次請求后1天,也就是在本地緩存86400秒。

打開瀏覽器,首次訪問該網(wǎng)站的一個網(wǎng)頁,該網(wǎng)頁中包含一張圖片的鏈接,于是該圖片請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 OK (表示服務器找到了此圖片并正確響應)
Cache-Control: max-age=86400 (從本次請求時間算起,允許該圖片在本地緩存86400秒)
Date: Sat, 14 May 2011 08:09:29 GMT (響應的時間,格林尼治時間)
于是,只要是在1天之內,使用本機的瀏覽器打開這個網(wǎng)頁,都不會再對這張圖片發(fā)出請求,而是直接使用本地緩存中的這張圖片??梢姡瑴p少了不必要的HTTP請求,
提高了網(wǎng)頁的響應速度。
很多網(wǎng)站框架性的組件都是長期不變的,因此我們可以設置更長的過期時間,如下所示:

打開瀏覽器,首次訪問該網(wǎng)站的一個網(wǎng)頁,該網(wǎng)頁中包含一張圖片的鏈接,于是該圖片請求的響應在Http Response Header中如下表達:
HTTP/1.1 200 OK (表示服務器找到了此圖片并正確響應)
Date: Sat, 14 May 2011 08:50:12 GMT(響應的時間,格林尼治時間)
Expires: Mon, 23 May 2011 16:00:00 GMT (該圖片的本地緩存到2011年5月23日16點為止,格林尼治時間)
那么這意味著只要在5月23日16點之前,在本機上訪問該網(wǎng)頁,都不會再對此圖片發(fā)出請求。
有人擔心如果這樣設置過期機制,一旦對這些組件做了更新,訪問者將不能收到變化,那豈不是也很遺憾。其實這有兩方面的解決方式:
一方面是網(wǎng)站的開發(fā)方,應該對圖片,樣式表文件和JS文件的命名方式進行改進,比如在文件名上加入版本號,這樣你一旦修改了組件內容,
就應該使組件擁有新的名稱,于是瀏覽器會發(fā)現(xiàn)本地沒有對這個組件緩存過,自然就會發(fā)起請求。
另一方面,訪問者可以通過瀏覽器的刷新功能強制對網(wǎng)頁中的組件重新發(fā)起請求。即使設置了過期機制,瀏覽器的刷新功能仍然會對所有頁面組件
發(fā)出請求的。
總結,本文的目的就是闡釋瀏覽器本地緩存與Web服務器緩存過期機制之間的交互關系,以及如何通過這種方式達到對性能的提升。
根據(jù)《高性能網(wǎng)站建設指南》一書中的統(tǒng)計,從瀏覽器向一個網(wǎng)頁發(fā)出請求算起,獲得網(wǎng)頁的HTML文檔的時間只占整個頁面應答完成時間的
5%,而剩余的95%時間全部是在請求和下載頁面中的各個組件。因此減少對頁面中組件的請求和下載,有效地利用瀏覽器緩存機制是十分有意義的。
相關文章
IIS6批量添加主機頭 IIS6批量綁定主機頭(利用IIS6導入導出XML)
因為對iis6添加了很多的主機頭,如果一個一個的添加很累,所以想到了批量添加,經(jīng)過測試發(fā)現(xiàn),可以用如下方法2012-12-12
Windows?Server?2012?基于iis的流媒體服務器的搭建圖文方法
IIS?Live?Smooth?Streaming(實時平滑流式處理)是微軟下一代流媒體解決方案。該技術是在IIS?web中集成媒體傳輸平臺IIS?media?services,實現(xiàn)利用標準?HTTP?Web?技術以及高級?Silverlight?功能,確保在互聯(lián)上傳輸質量最佳、播放流暢音視頻節(jié)目2023-06-06
Windows server 2003 服務器環(huán)境配置 新手簡明版
Windows server 2003 服務器環(huán)境配置 新手簡明版,第一次接觸win2003服務器的朋友應該也可以參考配置下。2011-01-01
Windows Server 2016 使用IIS配置FTP
本文主要介紹了Windows Server 2016 使用IIS配置FTP,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-10-10
windows server 2008 r2 DNS服務器配置圖文教程
DNS服務器的作用就是幫助用戶使用簡單好記的域名來訪問網(wǎng)絡上的主機和網(wǎng)絡服務。這篇文章主要介紹了windows server 2008 r2 DNS服務器配置圖文教程,需要的朋友可以參考下2018-04-04

