ASP.NET kimeneti gyorsítótározás (azaz statikus HTML) memóriaalapú volt egészen a .NET 4.0-ig. Ez azt jelenti, hogy ha az oldalunk sok gyorsítótárt tartalmaz, könnyen fogyasztható helyi memóriát. Most, a . OutputCacheProvider esetén a .NET 4.0-ban több lehetőségünk van saját gyorsítótár létrehozására. Például tárolhatjuk a HTML kimeneti gyorsítótárt egy memcache-alapú elosztott klaszterszerveren vagy a MongoDB-ben (egy gyakran használt dokumentumorientált adatbázis, olvassa el ezt http://msdn.microsoft.com/zh-cn/magazine/gg650661.aspx). Természetesen a gyorstárt fájlként is tárolhatjuk a merevlemezen, ami a legolcsóbb módja a skálázhatóság szempontjából, és ez a cikk arról szól, hogyan lehet egyedi fájlgyorsítótárt építeni.
1:OutputCacheProvider Az OutputCacheProvider egy absztrakt alaposztály, amelynek négy metódusát felülírni kell, amelyek a következők: Add hozzá a megadott elem kimeneti gyorsítótárba behelyezéséhez a módszert. Get metódus, amely a megadott elemre ad vissza egy hivatkozást a kimeneti gyorsítótárban. Eltávolítsa a metódót, hogy eltávolítsd a megadott elemet a kimeneti gyorsítótárból. A beállítás metódó segítségével a megadott elemet a kimeneti gyorsítótárba helyezi be, és felülírja az elemet, ha az gyorsatárban van.
2: Hozz létre saját fájlgyorsítótárkezelő osztályt A típus FileCacheProvider, a kód pedig a következő:
- public class FileCacheProvider : OutputCacheProvider
- {
- private static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
-
- public override void Initialize(string name, NameValueCollection attributes)
- {
- base.Initialize(name, attributes);
- CachePath = HttpContext.Current.Server.MapPath(attributes["cachePath"]);
- }
-
- public override object Add(string key, object entry, DateTime utcExpiry)
- {
- Object obj = Get(key);
- if (obj != null) //这一步很重要
- {
- return obj;
- }
- Set(key,entry,utcExpiry);
- return entry;
- }
-
- public override object Get(string key)
- {
- string path = ConvertKeyToPath(key);
- if (!File.Exists(path))
- {
- return null;
- }
- CacheItem item = null;
- using (FileStream file = File.OpenRead(path))
- {
- var formatter = new BinaryFormatter();
- item = (CacheItem)formatter.Deserialize(file);
- }
-
- if (item.ExpiryDate <= DateTime.Now.ToUniversalTime())
- {
- log.Info(item.ExpiryDate + "*" + key);
- Remove(key);
- return null;
- }
- return item.Item;
- }
-
-
- public override void Set(string key, object entry, DateTime utcExpiry)
- {
- CacheItem item = new CacheItem(entry, utcExpiry);
- string path = ConvertKeyToPath(key);
- using (FileStream file = File.OpenWrite(path))
- {
- BinaryFormatter formatter = new BinaryFormatter();
- formatter.Serialize(file, item);
- }
- }
-
- public override void Remove(string key)
- {
- string path = ConvertKeyToPath(key);
- if (File.Exists(path))
- File.Delete(path);
- }
-
- public string CachePath
- {
- get;
- set;
- }
-
- private string ConvertKeyToPath(string key)
- {
- string file = key.Replace('/', '-');
- file += ".txt";
- return Path.Combine(CachePath, file);
- }
- }
-
- [Serializable]
- public class CacheItem
- {
- public DateTime ExpiryDate;
- public object Item;
-
- public CacheItem(object entry, DateTime utcExpiry)
- {
- Item = entry;
- ExpiryDate = utcExpiry;
- }
- }
Kód másolása Két hely van, amelyekre különös figyelmet kell fordítani: Az Add metódusban van egy feltételes ítélet, amelyet így kell kezelni, különben a gyorsítótár mechanizmus gyorsítja az első eredményt, és a cache lejárati dátum után lejár, és nem épül újra. A példaprogramban egyszerűen a cache könyvtárba teszünk a gyorsatárt, és a tényleges projektgyakorlatban, figyelembe véve, hogy a gyorsatárban lévő oldalak ezrei lesznek, a könyvtárosztályozást kell végeznünk, különben a gyorsítótár fájlok megtalálása és olvasása hatékonysági szűk keresztmetszetet jelent, ami kimeríti a CPU-t.
3: Konfigurációs fájl
A Web.config-ban be kell állítanunk, hogy a cache kezelő egyedi FileCacheProvider legyen, azaz hozzáadni egy csomópontot a FileCacheProvider alá:- <caching>
- <outputCache defaultProvider="FileCache">
- <providers>
- <add name="FileCache" type="MvcApplication2.Common.FileCacheProvider" cachePath="~/Cache" />
- </providers>
- </outputCache>
- </caching>
Kód másolása
4: Gyorsítótár használata
Feltételezzük, hogy az MVC irányításában (ha ASP.NET oldalon szeretnéd használni, <%-ot kell beépíteni a page@OutputCache VaryByParam="none" Duration="10" %>), és láthatjuk, hogy az Index nem kerül gyorsgyorsatárba, míg az Index2 10 másodpercig gyorsankulcsban van.
- public class HomeController : Controller
- {
- private static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
- static string s_conn = "Data Source=192.168.0.77;Initial Catalog=luminjidb;User Id=sa;Password=sa;";
- public ActionResult Index()
- {
- 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()"))
- {
- ViewBag.Message = ds.Tables[0].Rows[0]["name"].ToString();
- }
- return View();
- }
-
- [OutputCache(Duration = 10, VaryByParam = "none")]
- public ActionResult Index2()
- {
- 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()"))
- {
- ViewBag.Message = ds.Tables[0].Rows[0]["name"].ToString();
- }
- return View();
- }
- }
Kód másolása 5: Nézd meg a hatást A fenti kód, miután eléri az Index2-t, gyorsítótár fájlt generál a Cache mappában, a következőként:
Most értékeljük a teljesítményösszehasonlítást a kimeneti gyorsítótár és a kimeneti gyorsítótár között, 100 egyidejű kérést szimulálva 100 felhasználótól:
|