• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            We do not always find visible happiness in proportion to visible virtue

            夢(mèng)幻白樺林

            SHARE

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              14 Posts :: 58 Stories :: 62 Comments :: 0 Trackbacks

            公告

            常用鏈接

            留言簿(5)

            搜索

            •  

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            介紹

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

                  基礎(chǔ)知識(shí)

                    1) 什么是”Last-Modified”?  

                    在瀏覽器第一次請(qǐng)求某一個(gè)URL時(shí),服務(wù)器端的返回狀態(tài)會(huì)是200,內(nèi)容是你請(qǐng)求的資源,同時(shí)有一個(gè)Last-Modified的屬性標(biāo)記此文件在服務(wù)期端最后被修改的時(shí)間,格式類似這樣: 

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

                    客戶端第二次請(qǐng)求此URL時(shí),根據(jù) HTTP 協(xié)議的規(guī)定,瀏覽器會(huì)向服務(wù)器傳送 If-Modified-Since 報(bào)頭,詢問該時(shí)間之后文件是否有被修改過: 

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

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

                    2) 什么是”Etag”? 

                    HTTP 協(xié)議規(guī)格說明定義ETag為“被請(qǐng)求變量的實(shí)體值” (參見 —— 章節(jié) 14.19)。 另一種說法是,ETag是一個(gè)可以與Web資源關(guān)聯(lián)的記號(hào)(token)。典型的Web資源可以一個(gè)Web頁(yè),但也可能是JSON或XML文檔。服務(wù)器單獨(dú)負(fù)責(zé)判斷記號(hào)是什么及其含義,并在HTTP響應(yīng)頭中將其傳送到客戶端,以下是服務(wù)器端返回的格式: 

                    ETag: "50b1c1d4f775c61:df3" 

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

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

                    如果ETag沒改變,則返回狀態(tài)304然后不返回,這也和Last-Modified一樣。本人測(cè)試Etag主要在斷點(diǎn)下載時(shí)比較有用。
                    

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

                    聰明的開發(fā)者會(huì)把Last-Modified 和ETags請(qǐng)求的http報(bào)頭一起使用,這樣可利用客戶端(例如瀏覽器)的緩存。因?yàn)榉?wù)器首先產(chǎn)生 Last-Modified/Etag標(biāo)記,服務(wù)器可在稍后使用它來(lái)判斷頁(yè)面是否已經(jīng)被修改。本質(zhì)上,客戶端通過將該記號(hào)傳回服務(wù)器要求服務(wù)器驗(yàn)證其(客 戶端)緩存。 
                    過程如下:
                            1. 客戶端請(qǐng)求一個(gè)頁(yè)面(A)。 
                            2. 服務(wù)器返回頁(yè)面A,并在給A加上一個(gè)Last-Modified/ETag。 
                            3. 客戶端展現(xiàn)該頁(yè)面,并將頁(yè)面連同Last-Modified/ETag一起緩存。 
                            4. 客戶再次請(qǐng)求頁(yè)面A,并將上次請(qǐng)求時(shí)服務(wù)器返回的Last-Modified/ETag一起傳遞給服務(wù)器。 
                            5. 服務(wù)器檢查該Last-Modified或ETag,并判斷出該頁(yè)面自上次客戶端請(qǐng)求之后還未被修改,直接返回響應(yīng)304和一個(gè)空的響應(yīng)體。


                  示例代碼

                    下面的例子描述如何使用服務(wù)器端代碼去操作客戶端緩存: 
                   
              //默認(rèn)緩存的秒數(shù)
              int secondsTime = 100;
               
              
            //判斷最后修改時(shí)間是否在要求的時(shí)間內(nèi)
              
            //如果服務(wù)器端的文件沒有被修改過,則返回狀態(tài)是304,內(nèi)容為空,這樣就節(jié)省了傳輸數(shù)據(jù)量。如果服務(wù)器端的文件被修改過,則返回和第一次請(qǐng)求時(shí)類似。
              if (request.Headers["If-Modified-Since"!= null && TimeSpan.FromTicks(DateTime.Now.Ticks - DateTime.Parse(request.Headers["If-Modified-Since"]).Ticks).Seconds < secondsTime)
              {
                  
            //測(cè)試代碼,在這里會(huì)發(fā)現(xiàn),當(dāng)瀏覽器返回304狀態(tài)時(shí),下面的日期并不會(huì)輸出
                  Response.Write(DateTime.Now);
             
                 response.StatusCode 
            = 304;
                 response.Headers.Add(
            "Content-Encoding""gzip");
                 response.StatusDescription 
            = "Not Modified";
              }
              
            else
              {
                 
            //輸出當(dāng)前時(shí)間
                 Response.Write(DateTime.Now);
             
                 
            //設(shè)置客戶端緩存狀態(tài)
                 SetClientCaching(response, DateTime.Now);
              }
             
              
            #region SetClientCaching..
              
            /// <summary>
              
            /// 設(shè)置客戶端緩存狀態(tài)
              
            /// </summary>
              
            /// <param name="response"></param>
              
            /// <param name="lastModified"></param>
              private void SetClientCaching(HttpResponse response, DateTime lastModified)
              {
                 response.Cache.SetETag(lastModified.Ticks.ToString());
                 response.Cache.SetLastModified(lastModified);
                 
            //public 以指定響應(yīng)能由客戶端和共享(代理)緩存進(jìn)行緩存。
                 response.Cache.SetCacheability(HttpCacheability.Public);
                 
            //是允許文檔在被視為陳舊之前存在的最長(zhǎng)絕對(duì)時(shí)間。
                 response.Cache.SetMaxAge(new TimeSpan(7000));
                 
            //將緩存過期從絕對(duì)時(shí)間設(shè)置為可調(diào)時(shí)間
                 response.Cache.SetSlidingExpiration(true);
              }
            #endregion



                    如果你的緩存是基于文件的方式,如XML或http中的.ashx處理,也可以使用下面的基于文件方式的客戶端緩存: 
                    
             #region SetFileCaching..
              
            /// <summary>
              
            /// 基于文件方式設(shè)置客戶端緩存
              
            /// </summary>
              
            /// <param name="fileName"></param>
              private void SetFileCaching(HttpResponse response, string fileName)
              {
                 response.AddFileDependency(fileName);
                  
            //基于處理程序文件依賴項(xiàng)的時(shí)間戳設(shè)置 ETag HTTP 標(biāo)頭。 
                 response.Cache.SetETagFromFileDependencies();
                 
            //基于處理程序文件依賴項(xiàng)的時(shí)間戳設(shè)置 Last-Modified HTTP 標(biāo)頭。
                 response.Cache.SetLastModifiedFromFileDependencies();
                 response.Cache.SetCacheability(HttpCacheability.Public);
                 response.Cache.SetMaxAge(
            new TimeSpan(7000));
                 response.Cache.SetSlidingExpiration(
            true);
             }
             
            #endregion
             

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


            上圖所使用的工具是在IE下運(yùn)行的HttpWatchPro,在Firefox下可以使用FireBug+YSlow進(jìn)行測(cè)試.
            YSlow是建立在FireBug基礎(chǔ)上運(yùn)行的一個(gè)小工具,它可以對(duì)你的網(wǎng)頁(yè)進(jìn)行分析為什么緩存,并給出評(píng)分和緩慢的原因.這個(gè)工具來(lái)自Yahoo的研發(fā)團(tuán)隊(duì),所以規(guī)則也是Yahoo制定的.

                  結(jié)論

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

                    
                    

            參考資料:

            301永久重定向?qū)崿F(xiàn)方式及302重定向

            理解ASP.NET與客戶端緩存之HTTP協(xié)議 

            如何利用客戶端緩存對(duì)網(wǎng)站進(jìn)行優(yōu)化?

            原文地址:http://www.cnblogs.com/lion.net/archive/2007/09/24/904717.html

            posted on 2007-09-25 13:23 colys 閱讀(394) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C#.Net

            无码人妻少妇久久中文字幕| 99精品久久精品| 久久最新免费视频| 伊人久久精品影院| 热re99久久精品国99热| 女人香蕉久久**毛片精品| 欧美日韩成人精品久久久免费看| 精品久久久久久久久免费影院| 亚洲精品高清国产一线久久| 国产欧美一区二区久久| 久久影视综合亚洲| 亚洲精品无码久久久久去q| 国产激情久久久久影院小草| 久久人人爽人人爽人人爽| MM131亚洲国产美女久久| 午夜精品久久久久成人| 免费观看成人久久网免费观看| 久久99精品久久久大学生| 91久久精品视频| 91精品国产9l久久久久| 奇米影视7777久久精品人人爽| 国产成人无码精品久久久久免费| 亚洲综合伊人久久综合| 久久青青国产| 国产激情久久久久影院小草| 996久久国产精品线观看| 久久久久免费精品国产| 国产精品VIDEOSSEX久久发布| 久久亚洲美女精品国产精品| 久久伊人影视| 亚洲国产综合久久天堂 | 久久天天躁狠狠躁夜夜2020一| 久久线看观看精品香蕉国产| 久久久噜噜噜www成人网| 久久久久亚洲av综合波多野结衣| 久久er国产精品免费观看8| 国产精品美女久久久久久2018| 久久久久免费精品国产| 中文无码久久精品| 五月丁香综合激情六月久久| 亚洲中文字幕无码久久精品1 |