• <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>
            流量統計:
            Rixu Blog (日需博客)
            日需博客,每日必需來踩踩哦..
            posts - 108,comments - 54,trackbacks - 0

            ASP.NET的輸出緩存(即靜態HTML)在.NET4.0前一直是基于內存的。這意味著如果我們的站點含有大量的緩存,則很容易消耗掉本機內存。現在,借助于.NET4.0中的OutputCacheProvider,我們可以有多種選擇創建自己的緩存。如,我們可以把HTML輸出緩存存儲到memcached分布式集群服務器,或者MongoDB中(一種常用的面向文檔數據庫,不妨閱讀本篇http://msdn.microsoft.com/zh-cn/magazine/gg650661.aspx)。當然,我們也可以把緩存作為文件存儲到硬盤上,考慮到可擴展性,這是一種最廉價的做法,本文就是介紹如果構建自定義文件緩存。

            1:OutputCacheProvider

            OutputCacheProvider是一個抽象基類,我們需要override其中的四個方法,它們分別是:

            Add 方法,將指定項插入輸出緩存中。

            Get 方法,返回對輸出緩存中指定項的引用。

            Remove 方法,從輸出緩存中移除指定項。

            Set 方法,將指定項插入輸出緩存中,如果該項已緩存,則覆蓋該項。

            2:創建自己的文件緩存處理類

            該類型為FileCacheProvider,代碼如下:

            1. public class FileCacheProvider : OutputCacheProvider  
            2. {  
            3. private static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);  
            4.  public override void Initialize(string name, NameValueCollection attributes)  
            5. {  
            6. base.Initialize(name, attributes);  
            7. CachePath = HttpContext.Current.Server.MapPath(attributes["cachePath"]);  
            8. }  
            9. public override object Add(string key, object entry, DateTime utcExpiry)  
            10. {  
            11. Object obj = Get(key);  
            12. if (obj != null//這一步很重要  
            13. {  
            14. return obj;  
            15. }  
            16. Set(key,entry,utcExpiry);  
            17. return entry;  
            18. }  
            19. public override object Get(string key)  
            20. {  
            21. string path = ConvertKeyToPath(key);  
            22. if (!File.Exists(path))  
            23. {  
            24. return null;  
            25. }  
            26. CacheItem item = null;  
            27. using (FileStream file = File.OpenRead(path))  
            28. {  
            29. var formatter = new BinaryFormatter();  
            30. item = (CacheItem)formatter.Deserialize(file);  
            31. }  
            32. if (item.ExpiryDate <= DateTime.Now.ToUniversalTime())  
            33. {  
            34. log.Info(item.ExpiryDate + "*" + key);  
            35. Remove(key);  
            36. return null;  
            37. }  
            38. return item.Item;  
            39. }  
            40. public override void Set(string key, object entry, DateTime utcExpiry)  
            41. {  
            42. CacheItem item = new CacheItem(entry, utcExpiry);  
            43. string path = ConvertKeyToPath(key);  
            44. using (FileStream file = File.OpenWrite(path))  
            45. {  
            46. BinaryFormatter formatter = new BinaryFormatter();  
            47. formatter.Serialize(file, item);  
            48. }  
            49. }  
            50. public override void Remove(string key)  
            51. {  
            52. string path = ConvertKeyToPath(key);  
            53. if (File.Exists(path))  
            54. File.Delete(path);  
            55.  }  
            56. public string CachePath  
            57. {  
            58. get;  
            59. set;  
            60. }  
            61. private string ConvertKeyToPath(string key)  
            62. {  
            63. string file = key.Replace('/''-');  
            64. file += ".txt";  
            65. return Path.Combine(CachePath, file);  
            66. }  
            67. }  
            68. [Serializable]  
            69. public class CacheItem  
            70. {  
            71. public DateTime ExpiryDate;  
            72. public object Item;  
            73. public CacheItem(object entry, DateTime utcExpiry)  
            74. {  
            75. Item = entry;  
            76. ExpiryDate = utcExpiry;  
            77. }  

            有兩個地方需要特別說明:

            在Add方法中,有一個條件判斷,必須做出這樣的處理,否則緩存機制將會緩存第一次的結果,過了有效期后緩存講失效并不再重建;

            在示例程序中,我們簡單的將緩存放到了Cache目錄下,在實際的項目實踐中,考慮到緩存的頁面將是成千上萬的,所以我們必須要做目錄分級,否則尋找并讀取緩存文件將會成為效率瓶頸,這會耗盡CPU。

            3:配置文件

            我們需要在Web.config中配置緩存處理程序是自定義的FileCacheProvider,即在 <system.web>下添加節點:

            1. <caching>  
            2. <outputCache defaultProvider="FileCache">  
            3. <providers>  
            4. <add name="FileCache" type="MvcApplication2.Common.FileCacheProvider" cachePath="~/Cache" />  
            5. </providers>  
            6. </outputCache>  
            7.  </caching> 

            4:緩存的使用

            我們假設在MVC的控制中使用(如果要在ASP.NET頁面中使用,則在頁面中包含<%@OutputCache VaryByParam="none" Duration="10" %>),可以看到,Index是未進行輸出緩存的,而Index2進行了輸出緩存,緩存時間為10秒。

            1. public class HomeController : Controller  
            2. {  
            3. private static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);  
            4. static string s_conn = "Data Source=192.168.0.77;Initial Catalog=luminjidb;User Id=sa;Password=sa;";  
            5. public ActionResult Index()  
            6. {  
            7. using (DataSet ds = Common.SqlHelper.ExecuteDataset(s_conn, CommandType.Text, "select top 1* from NameTb a, DepTb b where a.DepID = b.ID ORDER BY NEWID()"))  
            8. {  
            9. ViewBag.Message = ds.Tables[0].Rows[0]["name"].ToString();  
            10. }  
            11. return View();  
            12. }  
            13. [OutputCache(Duration = 10, VaryByParam = "none")]  
            14. public ActionResult Index2()  
            15. {  
            16. using (DataSet ds = Common.SqlHelper.ExecuteDataset(s_conn, CommandType.Text, "select top 1* from NameTb a, DepTb b where a.DepID = b.ID ORDER BY NEWID()"))  
            17. {  
            18. ViewBag.Message = ds.Tables[0].Rows[0]["name"].ToString();  
            19. }  
            20. return View();  
            21. }  

            5:查看下效果

            上面的代碼,在訪問了Index2后,將會在Cache文件夾下產生緩存文件,如下:

            現在,我們開始評價下有輸出緩存和無輸出緩存的性能對比,模擬100個用戶并發1000次請求如下:

            可以看到,有輸出緩存后,吞吐率明顯提高了10倍。

            6:代碼下載

            FileCacheProvider的原始代碼來自于網絡,我修改了其中的BUG,全部代碼下載如下:MvcApplication20110907.rar

            職業指導:

            在使用某一技能三個月后,你還不是專家,即便使用時間是三年,你還不是。馬爾科姆·格萊德威爾在《異類》一書中指出,成為一名真正的專家,需要10000小時。10000小時!如果一天用10小時,每天都學習,則大概需要3年時間。如果一天5小時,一年學習200天,則大概需要10年時間。10年!


            Logo
            作者:Gezidan
            出處:http://www.rixu.net    
            本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
            本文轉載自 http://www.cnblogs.com/luminji/archive/2011/09/08/2169955.html
            posted on 2011-09-28 09:43 日需博客 閱讀(330) 評論(0)  編輯 收藏 引用 所屬分類: C#技術文章轉載
            久久精品人人做人人爽97| 精品久久久久久亚洲| 久久www免费人成精品香蕉| 99久久免费只有精品国产| 久久亚洲AV无码精品色午夜| 久久久精品2019免费观看| 亚洲国产天堂久久综合网站| 久久久亚洲精品蜜桃臀| 国产精品久久久久久吹潮| 久久综合九色欧美综合狠狠| 久久伊人五月丁香狠狠色| 91精品国产91久久久久久蜜臀| 久久国内免费视频| 久久精品国产亚洲AV不卡| 狠狠狠色丁香婷婷综合久久俺| 久久伊人中文无码| 91精品国产高清久久久久久io| 国产成年无码久久久免费| 久久婷婷人人澡人人| 国内精品久久久人妻中文字幕| 久久婷婷人人澡人人| 99久久伊人精品综合观看| 久久精品夜色噜噜亚洲A∨ | 久久久精品久久久久久| 国产成人久久AV免费| 一本久久a久久精品亚洲| 看全色黄大色大片免费久久久| 99久久99久久精品国产片| 久久99国产精品99久久| 久久99国产综合精品| 久久久女人与动物群交毛片| 久久www免费人成看片| 亚洲精品无码久久久久去q | 久久香蕉一级毛片| 中文精品久久久久国产网址| 久久国产精品一国产精品金尊| 亚洲av伊人久久综合密臀性色| 午夜天堂精品久久久久| 久久久久久免费视频| 伊人久久大香线蕉av一区| 午夜精品久久久久久久|