在小型Web系統中使用快取加速訪問
阿新 • • 發佈:2019-02-12
在高併發的現代Web系統中,快取體系是繞不開的話題。一直以來我們開發的系統處於內網環境中,而且伺服器資源相對負載來說比較富裕,從未使用快取。大型的Web系統往往會使用MemCache,Redis等快取資料庫來加速訪問,還有諸如全站靜態化和CDN等技術。而受制於技術複雜度。小型Web使用.NET自帶的快取技術,也可以非常好的提高訪問速度。
在油水井圖片庫這個專案中,由於在模糊查詢中不當的應用了Count()方法。導致模糊查詢偶爾會失去響應。於是在這個系統中加了一層簡單的快取。
快取本質很簡單,就是將原始資料預讀到一個可以高速訪問的區域一般就是記憶體中。
使用快取的代價就是要維護原始資料與快取的同步,在做各種增刪改操作的時候需要一併更新快取。快取可以分為頁面/檔案快取和資料快取。
ASP.NET MVC對.NET快取進行了一層包裝,可以很優雅的對頁面進行快取。快取資料程式碼如下:
在油水井圖片庫這個專案中,由於在模糊查詢中不當的應用了Count()方法。導致模糊查詢偶爾會失去響應。於是在這個系統中加了一層簡單的快取。
快取本質很簡單,就是將原始資料預讀到一個可以高速訪問的區域一般就是記憶體中。
使用快取的代價就是要維護原始資料與快取的同步,在做各種增刪改操作的時候需要一併更新快取。快取可以分為頁面/檔案快取和資料快取。
ASP.NET MVC對.NET快取進行了一層包裝,可以很優雅的對頁面進行快取。快取資料程式碼如下:
public class CacheHelper { /// <summary> /// 獲取資料快取 /// </summary> /// <param name="CacheKey">鍵</param> public static object GetCache(string CacheKey) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; return objCache[CacheKey]; } /// <summary> /// 設定資料快取 /// </summary> public static void SetCache(string CacheKey, object objObject) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; objCache.Insert(CacheKey, objObject); //永不過期 } /// <summary> /// 設定資料快取 /// </summary> public static void SetCache(string CacheKey, object objObject, TimeSpan Timeout) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; objCache.Insert(CacheKey, objObject, null, DateTime.MaxValue, Timeout, System.Web.Caching.CacheItemPriority.NotRemovable, null); } /// <summary> /// 設定資料快取 /// </summary> public static void SetCache(string CacheKey, object objObject, DateTime absoluteExpiration, TimeSpan slidingExpiration) { System.Web.Caching.Cache objCache = HttpRuntime.Cache; objCache.Insert(CacheKey, objObject, null, absoluteExpiration, slidingExpiration); } /// <summary> /// 移除指定資料快取 /// </summary> public static void RemoveAllCache(string CacheKey) { System.Web.Caching.Cache _cache = HttpRuntime.Cache; _cache.Remove(CacheKey); } /// <summary> /// 移除全部快取 /// </summary> public static void RemoveAllCache() { System.Web.Caching.Cache _cache = HttpRuntime.Cache; IDictionaryEnumerator CacheEnum = _cache.GetEnumerator(); while (CacheEnum.MoveNext()) { _cache.Remove(CacheEnum.Key.ToString()); } } }
由於我們的快取是後加的,因此需要在某處執行一個初始化的過程。結果發現,在記憶體中初始化快取的執行時間長達2分鐘!以至Ajax請求超時。最後解決了這個問題。當快取初始化成功後,模糊查詢的執行速度得到了很大提升。我們把兩個程式釋出到伺服器的不同埠上,在其他外部條件完全一致的情況下對訪問時間進行了比較:
未使用快取之前:
在實測中發現請求頁面時,速度幾乎沒有提升。可能是因為頁面本身就非常簡單,提速不明顯。而請求資料時速度提升非常大。通過圖片可以很清楚的看到,加上快取後,響應時間下降了80%-90%,某些情況下甚至下降到了5%。達到了預期目的。