一本大道久久香蕉成人网,人妻少妇精品无码专区APP ,欧美人与性动交Α欧美精品,人妻熟妇乱又伦精品视频app

IIS 設(shè)置靜態(tài)內(nèi)容緩存時(shí)間

時(shí)間:2014-09-11 來(lái)源:天津文率科技

今天有個(gè)人網(wǎng)絡(luò)公司的負(fù)責(zé)人加了我QQ,問(wèn)我怎么設(shè)置靜態(tài)內(nèi)容緩存時(shí)間,是通過(guò)我以前寫(xiě)過(guò)的一篇文章,《如何設(shè)置靜態(tài)內(nèi)容緩存時(shí)間》http://www.douban.com/note/361486825/ 


我們公司目前做的網(wǎng)站都是apche加php的 iis,自從我大2之后還真沒(méi)用過(guò)了,因?yàn)闆](méi)有apche配合php好,而且apche配置起來(lái)很方便,比較主流。

于是我就在網(wǎng)上找了下關(guān)于IIS設(shè)置靜態(tài)內(nèi)容緩存時(shí)間的教程,在這里奉獻(xiàn)給大家。

關(guān)于IIS設(shè)置靜態(tài)內(nèi)容緩存時(shí)間


在這里給大家介紹一下:我們的網(wǎng)站中往往包含大量的頁(yè)面組件,比如圖片、樣式表文件、JS腳本文件和Flash動(dòng)畫(huà)。這些組件的變化頻率非常低,尤其是那些構(gòu)成網(wǎng)站基本框架的組件,

  幾乎不會(huì)發(fā)生變化。我們可以將這些變化率很低的組件看作靜態(tài)內(nèi)容,利用IIS的內(nèi)容過(guò)期機(jī)制和瀏覽器的本地緩存機(jī)制將它們?cè)谠L(fǎng)問(wèn)者的電腦硬盤(pán)中保存一段時(shí)間。

  當(dāng)訪(fǎng)問(wèn)者訪(fǎng)問(wèn)你的網(wǎng)站時(shí),如果這些存在本地的靜態(tài)內(nèi)容沒(méi)有過(guò)期,瀏覽器會(huì)從本地硬盤(pán)中裝載,而不去向服務(wù)器發(fā)出請(qǐng)求。

  如果你使用Fiddler這樣的工具跟蹤網(wǎng)頁(yè)訪(fǎng)問(wèn),你會(huì)清楚地看到雖然只是訪(fǎng)問(wèn)一個(gè)頁(yè)面,但是發(fā)出的Http請(qǐng)求和應(yīng)答卻不止一個(gè)。網(wǎng)頁(yè)中的每張圖片,每個(gè)

  JS腳本文件,每個(gè)CSS文件,都會(huì)引發(fā)一次請(qǐng)求和應(yīng)答。因此如果想讓網(wǎng)頁(yè)的訪(fǎng)問(wèn)速度快起來(lái),減少Http的請(qǐng)求數(shù)量,降低從服務(wù)器下載內(nèi)容的次數(shù)是有效途徑。

  而使用了內(nèi)容過(guò)期機(jī)制后可以就實(shí)現(xiàn)這樣的目的,這就是使用內(nèi)容過(guò)期機(jī)制的意義。

  大多數(shù)的Web開(kāi)發(fā)者都玩過(guò)IIS 6或IIS 7,但是又有多少人仔細(xì)觀察過(guò)HTTP Headers或HTTP Response Headers標(biāo)簽中的內(nèi)容呢?此處我以IIS 6 為例,

  默認(rèn)情況下此標(biāo)簽中的界面如下圖:

此時(shí),如果向該網(wǎng)站的一個(gè)網(wǎng)頁(yè)發(fā)出請(qǐng)求,該網(wǎng)頁(yè)中包含了一張圖片的鏈接,那么在獲取到該網(wǎng)頁(yè)的HTML文檔之后,瀏覽器會(huì)繼續(xù)對(duì)這張圖片發(fā)出請(qǐng)求,該請(qǐng)求的響應(yīng)在Http Response Header中如下表達(dá):

  HTTP/1.1 200 ok (表示服務(wù)器找到了此圖片并正確響應(yīng))
  Date:Thu, 04 Feb 2010 08:25:38 GMT (響應(yīng)的時(shí)間,格林尼治時(shí)間)
  Last-Modified:Wed, 03 Jan 2009 01:55:06 GMT(圖片最后被修改的時(shí)間,格林尼治時(shí)間)

  這張圖片會(huì)被瀏覽器保存在本地硬盤(pán)的IE臨時(shí)文件夾中。使用同一個(gè)瀏覽器窗口在同一個(gè)會(huì)話(huà)中再次訪(fǎng)問(wèn)到這個(gè)頁(yè)面,則頁(yè)面中的組件都不再重新請(qǐng)求。

  當(dāng)在這臺(tái)機(jī)器上打開(kāi)另一個(gè)瀏覽器窗口(另一個(gè)會(huì)話(huà))又一次訪(fǎng)問(wèn)此頁(yè)面時(shí),由于這張圖已經(jīng)在本地保存了,但是瀏覽器剛才的響應(yīng)中并沒(méi)有規(guī)定內(nèi)容的過(guò)期機(jī)制,因此瀏覽器仍會(huì)向服務(wù)器發(fā)出一次請(qǐng)求:

  If-Modified-Since: Wed, 03 Jan 2009 01:55:06 GMT (詢(xún)問(wèn)服務(wù)器,我本地這張圖片的最后修改時(shí)間是這個(gè),在此時(shí)間之后你那有沒(méi)有更新的版本?)
  If-None-Matched: "abdkfkdkdkdjkjkfkfd" (這是一段ETag編碼,是服務(wù)器端給該組件的唯一標(biāo)示)

  服務(wù)器收到請(qǐng)求后檢查被請(qǐng)求的圖片,發(fā)現(xiàn)它的最近修改時(shí)間還是Wed, 03 Jan 2009 01:55:06 GMT ,于是響應(yīng)請(qǐng)求:

  HTTP/1.1 304 Not Modified (請(qǐng)求的圖片找到了,并且沒(méi)有被改變過(guò))
  Date:Thu, 04 Feb 2010 08:25:38 GMT (響應(yīng)的時(shí)間)

  瀏覽器收到這個(gè)響應(yīng)就知道它可以放心地使用本地存儲(chǔ)的這張圖片了,不必再?gòu)姆?wù)器重新下載該組件。

  由此可見(jiàn),IIS Http Headers標(biāo)簽的默認(rèn)設(shè)置是不禁止瀏覽器緩存的,但是也沒(méi)有告訴組件保存過(guò)期的時(shí)間,因此瀏覽器將組件保存在本地后,

  每次訪(fǎng)問(wèn)都會(huì)詢(xún)問(wèn)服務(wù)器此組件是否過(guò)期,如果沒(méi)過(guò)期則使用本地保存的內(nèi)容,否則從服務(wù)器下載內(nèi)容。 可以看出它只減少了從服務(wù)器下載內(nèi)容的次數(shù),

  并沒(méi)有減少向服務(wù)器發(fā)出請(qǐng)求的次數(shù),請(qǐng)求和響應(yīng)依然耗費(fèi)了時(shí)間。

  在IIS中定位到網(wǎng)站存放圖片的文件夾,然后打開(kāi)屬性窗口,在HTTP Headers中做出如下選擇,要求組件的過(guò)期時(shí)間為本次請(qǐng)求后1天,也就是在本地緩存86400秒。

 打開(kāi)瀏覽器,首次訪(fǎng)問(wèn)該網(wǎng)站的一個(gè)網(wǎng)頁(yè),該網(wǎng)頁(yè)中包含一張圖片的鏈接,于是該圖片請(qǐng)求的響應(yīng)在Http Response Header中如下表達(dá):

  HTTP/1.1 200 OK (表示服務(wù)器找到了此圖片并正確響應(yīng))
  Cache-Control: max-age=86400 (從本次請(qǐng)求時(shí)間算起,允許該圖片在本地緩存86400秒)
  Date: Sat, 14 May 2011 08:09:29 GMT (響應(yīng)的時(shí)間,格林尼治時(shí)間)

  于是,只要是在1天之內(nèi),使用本機(jī)的瀏覽器打開(kāi)這個(gè)網(wǎng)頁(yè),都不會(huì)再對(duì)這張圖片發(fā)出請(qǐng)求,而是直接使用本地緩存中的這張圖片??梢?jiàn),減少了不必要的HTTP請(qǐng)求,提高了網(wǎng)頁(yè)的響應(yīng)速度。

  很多網(wǎng)站框架性的組件都是長(zhǎng)期不變的,因此我們可以設(shè)置更長(zhǎng)的過(guò)期時(shí)間,如下所示:

打開(kāi)瀏覽器,首次訪(fǎng)問(wèn)該網(wǎng)站的一個(gè)網(wǎng)頁(yè),該網(wǎng)頁(yè)中包含一張圖片的鏈接,于是該圖片請(qǐng)求的響應(yīng)在Http Response Header中如下表達(dá):

  HTTP/1.1 200 OK (表示服務(wù)器找到了此圖片并正確響應(yīng))
  Date: Sat, 14 May 2011 08:50:12 GMT(響應(yīng)的時(shí)間,格林尼治時(shí)間)
  Expires: Mon, 23 May 2011 16:00:00 GMT (該圖片的本地緩存到2011年5月23日16點(diǎn)為止,格林尼治時(shí)間)

  那么這意味著只要在5月23日16點(diǎn)之前,在本機(jī)上訪(fǎng)問(wèn)該網(wǎng)頁(yè),都不會(huì)再對(duì)此圖片發(fā)出請(qǐng)求。

  有人擔(dān)心如果這樣設(shè)置過(guò)期機(jī)制,一旦對(duì)這些組件做了更新,訪(fǎng)問(wèn)者將不能收到變化,那豈不是也很遺憾。其實(shí)這有兩方面的解決方式:

  一方面是網(wǎng)站的開(kāi)發(fā)方,應(yīng)該對(duì)圖片,樣式表文件和JS文件的命名方式進(jìn)行改進(jìn),比如在文件名上加入版本號(hào),這樣你一旦修改了組件內(nèi)容,就應(yīng)該使組件擁有新的名稱(chēng),于是瀏覽器會(huì)發(fā)現(xiàn)本地沒(méi)有對(duì)這個(gè)組件緩存過(guò),自然就會(huì)發(fā)起請(qǐng)求。

  另一方面,訪(fǎng)問(wèn)者可以通過(guò)瀏覽器的刷新功能強(qiáng)制對(duì)網(wǎng)頁(yè)中的組件重新發(fā)起請(qǐng)求。即使設(shè)置了過(guò)期機(jī)制,瀏覽器的刷新功能仍然會(huì)對(duì)所有頁(yè)面組件發(fā)出請(qǐng)求的。

  總結(jié),本文的目的就是闡釋瀏覽器本地緩存與Web服務(wù)器緩存過(guò)期機(jī)制之間的交互關(guān)系,以及如何通過(guò)這種方式達(dá)到對(duì)性能的提升。

  從瀏覽器向一個(gè)網(wǎng)頁(yè)發(fā)出請(qǐng)求算起,獲得網(wǎng)頁(yè)的HTML文檔的時(shí)間只占整個(gè)頁(yè)面應(yīng)答完成時(shí)間的5%,而剩余的95%時(shí)間全部是在請(qǐng)求和下載頁(yè)面中的各個(gè)組件。因此減少對(duì)頁(yè)面中組件的請(qǐng)求和下載,有效地利用瀏覽器緩存機(jī)制是十分有意義的。

久久国产精品99久久久久久| 欧美videosfree性派对| 亚洲一区域二区域三区域四区域 | jux被夫上司欺辱的人妻| 含羞草国产亚洲精品岁国产精品 | 国产在线观看国偷精品产拍| 亚亚洲精品黑人巨大在线播放| 久久av无码av高潮av| 欧美午夜一区二区福利视频| 麻豆果冻传媒AV精品一区| 女人与公拘交酡免费网站| 亚洲精品无码成人久久久| 日日碰狠狠躁久久躁| 国产suv精品一区二区四| 欧美精产国品一二三产品区别| 色欲人妻综合aaaaaaaa网| 久久国产精品波多野结衣AV| 亚洲香蕉成人AV网站在线观看| 免费看小12萝裸体视频国产 | 女公务员人妻呻吟求饶| 国产丰满大乳大屁股A片图片| 中文无码AV一区二区三区| 性做久久久久久久久不卡| 欧美性猛交╳xxx富婆| 国产亚洲精品久久久久久久| 亚洲欧美日韩高清一区| 香蕉欧美成人精品A∨在线观看| 亚洲av无码国产精品麻豆天美| 国产精品无码A∨精品影院| 免费人成视频x8x8入口app| 国产产无码乱码精品久久鸭| 老色鬼永久精品网站| 色拍拍在线精品视频| 久久精品免视看国产成人不卡| 久久久久亚洲AV成人无码电影| 母亲6韩国电视剧免费观看| 精品无码久久久久久国产百度| 国产suv精品一区二区四| 久久亚洲熟女cc98cm| 国产男女猛烈无遮挡免费网站| 末成年女A片一区二区|