欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

--- 如何利用客戶端緩存對網站進行優化?

系統 2004 0

?介紹 ??????? 你的網站在并發訪問很大并且無法承受壓力的情況下,你會選擇如何優化? ?
??????? 很多人首先會想從服務器緩存方面著手對程序進行優化,許多不同的服務器緩存方式都有他們自己的特點,像我曾經參與的一些項目中,根據緩存的命中率不同使用過 Com+/Enterprise Libiary Caching/Windows服務,靜態文件等方式的服務器端緩存和 HTTP Compression 技術,但客戶端緩存往往卻被人們忽略了,即使服務器的緩存讓你的頁面訪問起來非常地快,但她依然需要依賴瀏覽器下載并輸出,而當你加入客戶端緩存時,會給你帶來非常多的好處.因為她可以對站點中訪問最頻繁的頁進行緩存充分地提高 Web 服務器的吞吐量(通常以每秒的請求數計算)以提升應用程序性能和可伸縮性。?
??????? 一個在線購物調查顯示,大多數人愿意去商店排隊,但在在線購物時卻不愿意等待。Websense調查公司稱多達70%的上網者表示不愿意在頁面讀取上超過10秒鐘。超過70%的人會因為中途速度過慢而取消當前的訂單。

????? 基礎知識

??????? 1) 什么是”Last-Modified”? ?

??????? 在瀏覽器第一次請求某一個URL時,服務器端的返回狀態會是200,內容是你請求的資源,同時有一個Last-Modified的屬性標記此文件在服務期端最后被修改的時間,格式類似這樣:?

??????? Last-Modified: Fri, 12 May 2006 18:53:33 GMT?

??????? 客戶端第二次請求此URL時,根據 HTTP 協議的規定,瀏覽器會向服務器傳送 If-Modified-Since 報頭,詢問該時間之后文件是否有被修改過:?

??????? If-Modified-Since: Fri, 12 May 2006 18:53:33 GMT?

??????? 如果服務器端的資源沒有變化,則自動返回 HTTP 304 (Not Changed.)狀態碼,內容為空,這樣就節省了傳輸數據量。當服務器端代碼發生改變或者重啟服務器時,則重新發出資源,返回和第一次請求時類似。從而保證不向客戶端重復發出資源,也保證當服務器有變化時,客戶端能夠得到最新的資源。?

??????? 2) 什么是”Etag”??

??????? HTTP 協議規格說明定義ETag為“被請求變量的實體值” ( 參見 —— 章節 14.19 )。 另一種說法是,ETag是一個可以與Web資源關聯的記號(token)。典型的Web資源可以一個Web頁,但也可能是JSON或XML文檔。服務器單獨負責判斷記號是什么及其含義,并在HTTP響應頭中將其傳送到客戶端,以下是服務器端返回的格式:?

??????? ETag: "50b1c1d4f775c61:df3"?

??????? 客戶端的查詢更新格式是這樣的:?

??????? If-None-Match: W/"50b1c1d4f775c61:df3"?

??????? 如果ETag沒改變,則返回狀態304然后不返回,這也和Last-Modified一樣。本人測試Etag主要在斷點下載時比較有用。
????????

????? Last-Modified和Etags如何幫助提高性能?

??????? 聰明的開發者會把Last-Modified 和ETags請求的http報頭一起使用,這樣可利用客戶端(例如瀏覽器)的緩存。因為服務器首先產生 Last-Modified/Etag標記,服務器可在稍后使用它來判斷頁面是否已經被修改。本質上,客戶端通過將該記號傳回服務器要求服務器驗證其(客戶端)緩存。?
??????? 過程如下:
???????? ??????? 1.?客戶端請求一個頁面(A)。?
???????? ??????? 2.?服務器返回頁面A,并在給A加上一個Last-Modified/ETag。?
???????? ??????? 3.?客戶端展現該頁面,并將頁面連同Last-Modified/ETag一起緩存。?
???????? ??????? 4.?客戶再次請求頁面A,并將上次請求時服務器返回的Last-Modified/ETag一起傳遞給服務器。?
???????? ??????? 5.?服務器檢查該Last-Modified或ETag,并判斷出該頁面自上次客戶端請求之后還未被修改,直接返回響應304和一個空的響應體。

????? 示例代碼

??????? 下面的例子描述如何使用服務器端代碼去操作客戶端緩存:?

????????

?1 ? // 默認緩存的秒數
?2 ? int ?secondsTime? = ? 100 ;
?3 ?
?4 ? // 判斷最后修改時間是否在要求的時間內
?5 ? // 如果服務器端的文件沒有被修改過,則返回狀態是304,內容為空,這樣就節省了傳輸數據量。如果服務器端的文件被修改過,則返回和第一次請求時類似。
?6 ? if ?(request.Headers[ " If-Modified-Since " ]? != ? null ? && ?TimeSpan.FromTicks(DateTime.Now.Ticks? - ?DateTime.Parse(request.Headers[ " If-Modified-Since " ]).Ticks).Seconds? < ?secondsTime)
?7 ? {
?8 ? ???? // 測試代碼,在這里會發現,當瀏覽器返回304狀態時,下面的日期并不會輸出
?9 ? ????Response.Write(DateTime.Now);
10 ?
11 ? ????response.StatusCode? = ? 304 ;
12 ? ????response.Headers.Add( " Content-Encoding " ,? " gzip " );
13 ? ????response.StatusDescription? = ? " Not?Modified " ;
14 ? }
15 ? else
16 ? {
17 ? ???? // 輸出當前時間
18 ? ????Response.Write(DateTime.Now);
19 ?
20 ? ???? // 設置客戶端緩存狀態
21 ? ????SetClientCaching(response,?DateTime.Now);
22 ? }
23 ?
24 ? #region ?SetClientCaching ..
25 ? /// ? <summary>
26 ? /// ?設置客戶端緩存狀態
27 ? /// ? </summary>
28 ? /// ? <param?name="response"></param>
29 ? /// ? <param?name="lastModified"></param>
30 ? private ? void ?SetClientCaching(HttpResponse?response,?DateTime?lastModified)
31 ? {
32 ? ????response.Cache.SetETag(lastModified.Ticks.ToString());
33 ? ????response.Cache.SetLastModified(lastModified);
34 ? ???? // public?以指定響應能由客戶端和共享(代理)緩存進行緩存。
35 ? ????response.Cache.SetCacheability(HttpCacheability.Public);
36 ? ???? // 是允許文檔在被視為陳舊之前存在的最長絕對時間。
37 ? ????response.Cache.SetMaxAge( new ?TimeSpan( 7 ,? 0 ,? 0 ,? 0 ));
38 ? ???? // 將緩存過期從絕對時間設置為可調時間
39 ? ????response.Cache.SetSlidingExpiration( true );
40 ? }
41 ? #endregion



??????? 如果你的緩存是基于文件的方式,如XML或http中的.ashx處理,也可以使用下面的基于文件方式的客戶端緩存:?

????????

?1 ? #region ?SetFileCaching ..
?2 ? /// ? <summary>
?3 ? /// ?基于文件方式設置客戶端緩存
?4 ? /// ? </summary>
?5 ? /// ? <param?name="fileName"></param>
?6 ? private ? void ?SetFileCaching(HttpResponse?response,? string ?fileName)
?7 ? {
?8 ? ????response.AddFileDependency(fileName);
?9 ? ???? // 基于處理程序文件依賴項的時間戳設置?ETag?HTTP?標頭。?
10 ? ????response.Cache.SetETagFromFileDependencies();
11 ? ???? // 基于處理程序文件依賴項的時間戳設置?Last-Modified?HTTP?標頭。
12 ? ????response.Cache.SetLastModifiedFromFileDependencies();
13 ? ????response.Cache.SetCacheability(HttpCacheability.Public);
14 ? ????response.Cache.SetMaxAge( new ?TimeSpan( 7 ,? 0 ,? 0 ,? 0 ));
15 ? ????response.Cache.SetSlidingExpiration( true );
16 ? }
17 ? #endregion


??????? 使用后的效果如下圖所示:


上圖所使用的工具是在IE下運行的 HttpWatchPro ,在Firefox下可以使用 FireBug + YSlow 進行測試.
YSlow是建立在FireBug基礎上運行的一個小工具,它可以對你的網頁進行分析為什么緩存,并給出評分和緩慢的原因.這個工具來自Yahoo的研發團隊,所以規則也是Yahoo制定的.

????? 結論

??????? 我們已經看了如何使用客戶端緩存減少帶寬和計算的方法,如前所述,如果能正確合理的利用各種不同的緩存,他們會給你帶來很多的好處.我希望本文已為你當下或將來基于Web的項目提供了精神食糧,并正確地在底層利用Last- Modified和ETag響應頭去優化你的項目。

?

出處: http://blog.csdn.net/houjianxun/archive/2007/09/25/1799328.aspx ?

?

?

?

--- 如何利用客戶端緩存對網站進行優化?


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 一级午夜a毛片免费视频 | 亚洲日本一区二区三区 | 99精品视频在线在线视频观看 | 丁香六月婷婷在线 | 九九九九九热 | 精品国产九九 | 亚洲激情视频网 | 免费啪视频在线观看免费的 | 全免费午夜一级毛片一级毛 | 日日日日日| 亚洲欧美一区二区三区国产精品 | 99re6热只有精品免费观看 | 中文字幕精品一区二区三区精品 | 久久精品在这里 | 国产福利自产拍在线观看 | 国产精品视频网站 | 国产一区二区三区乱码 | 欧洲中文字幕 | 色多多成视频人在线观看 | 日本老熟妇毛茸茸 | 天天爱夜夜操 | 99re在线精品 | 精品亚洲永久免费精品 | 国产高清性xxxxxxxx | 一级毛片在线观看视频 | 国产毛片片精品天天看视频 | 亚洲欧美视频在线播放 | 久久国产日韩 | 91精品国产综合久久婷婷香蕉 | 精品国内在线视频2019百度 | 婷婷天天操 | 欧美一区二区三区四区不卡 | 中文字幕在线免费看 | 日韩在线免费看网站 | 色综合99天天亚洲 | 国产精品日韩欧美 | 精品伊人久久久大香线蕉欧美 | 亚洲国产aⅴ成人精品无吗 最新国产网址 | 久久精品视频在线观看 | 爱爱视频网站 | 超碰97免费在线 |