国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > IIS > 正文

IIS的內容緩存過期機制實踐 有效提高站點性能

2024-08-29 03:12:39
字體:
來源:轉載
供稿:網友
我們的網站中往往包含大量的頁面組件,比如圖片、樣式表文件、JS腳本文件和Flash動畫。這些組件的變化頻率非常低,尤其是那些構成網站基本框架的組件,

幾乎不會發生變化。我們可以將這些變化率很低的組件看作靜態內容,利用IIS的內容過期機制和瀏覽器的本地緩存機制將它們在訪問者的電腦硬盤中保存一段時間。

當訪問者訪問你的網站時,如果這些存在本地的靜態內容沒有過期,瀏覽器會從本地硬盤中裝載,而不去向服務器發出請求。

如果你使用Fiddler這樣的工具跟蹤網頁訪問,你會清楚地看到雖然只是訪問一個頁面,但是發出的Http請求和應答卻不止一個。網頁中的每張圖片,每個

JS腳本文件,每個CSS文件,都會引發一次請求和應答。因此如果想讓網頁的訪問速度快起來,減少Http的請求數量,降低從服務器下載內容的次數是有效途徑。

而使用了內容過期機制后可以就實現這樣的目的,這就是使用內容過期機制的意義。

大多數的Web開發者都玩過IIS 6或IIS 7,但是又有多少人仔細觀察過HTTP Headers或HTTP Response Headers標簽中的內容呢?此處我以IIS 6 為例,

默認情況下此標簽中的界面如下圖:

此時,如果向該網站的一個網頁發出請求,該網頁中包含了一張圖片的鏈接,那么在獲取到該網頁的HTML文檔之后,瀏覽器會繼續對這張圖片發出請求,該請求的響應在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臨時文件夾中。使用同一個瀏覽器窗口在同一個會話中再次訪問到這個頁面,
則頁面中的組件都不再重新請求。

當在這臺機器上打開另一個瀏覽器窗口(另一個會話)又一次訪問此頁面時,由于這張圖已經在本地保存了,但是瀏覽器
剛才的響應中并沒有規定內容的過期機制,因此瀏覽器仍會向服務器發出一次請求:
If-Modified-Since: Wed, 03 Jan 2009 01:55:06 GMT (詢問服務器,我本地這張圖片的最后修改時間是這個,在此時間之后你那有沒有更新的版本?)
If-None-Matched: "abdkfkdkdkdjkjkfkfd" (這是一段ETag編碼,是服務器端給該組件的唯一標示)

服務器收到請求后檢查被請求的圖片,發現它的最近修改時間還是Wed, 03 Jan 2009 01:55:06 GMT ,于是響應請求:
HTTP/1.1 304 Not Modified (請求的圖片找到了,并且沒有被改變過)

Date:Thu, 04 Feb 2010 08:25:38 GMT (響應的時間)
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 琼海市| 法库县| 中山市| 白玉县| 保山市| 太谷县| 浮山县| 建德市| 梁河县| 宜兰市| 杭州市| 和田县| 两当县| 会同县| 义乌市| 万全县| 临城县| 富平县| 海门市| 永仁县| 和林格尔县| 中江县| 翁牛特旗| 九寨沟县| 广河县| 繁昌县| 光山县| 长丰县| 郁南县| 定日县| 佛冈县| 丁青县| 东莞市| 龙江县| 高雄市| 长宁县| 贵阳市| 富源县| 扎兰屯市| 吉林省| 贵港市|