ASP.NET的Cache机制提供页面、用户控件及自定义的缓存,本文提供一种在业务层缓存业务对象的方法。
利用ASP.NET的Cache机制可以提高Web服务器的整体性能。ASP.net在Presentation Layer提供页面级和用户控件级的缓存,并且只要通过声明即可实现缓存功能,使用的确便捷。
但是Presentation Layer的缓存存在以下问题:
- 适合于相对静态的内容(相当于Java的Session Bean),如产品列表等;
- 对基于不同客户的内容(相当于Java的Entity Bean),要通过QueryString以缓存不同内容;
- 特别是相同客户业务资料需要以不同的方式呈现的时候(如全部/部分、报表/图表等),需要消耗大量资源;
- 当相关内容更新时,很难更新(或作废)已缓存的内容。
另外,从系统资源开销的角度,网络访问和磁盘访问的开销远大于页面的Rendering,因而减少数据库的访问是系统优化的重点。
综上所述,小鸡射手在项目中采用了在Business Layer缓存的方法。具体实现如下:
- 定义CachedObject类,包装HttpContext.Current.Cache对象
- 缓存淘汰机制采用每访问一次增加n秒有效期,有效期分为短、中、长和永久四档
- 在每个业务类实现中增加私有的CachedObject成员变量_cache
- 获取客户数据的业务方法模版如下:
public Something GetSomething()
{
string cacheKey = GetCacheKey("GetSomething");
if(null == _cache[cacheKey])
_cache[cacheKey] = GetFromDatabase(); // 缺省为中档有效期
return _cache[cacheKey] as Something;
}
- 设置数据的业务方法模版如下:
public void SetSomething(Something value)
{
SetToDatabase(value);
string cacheKey = GetCacheKey("GetSomething");
_cache.remove(cacheKey);
}
- GetCacheKey()用于产生某客户某类操作的cache key值,如:
string GetCacheKey(string unique)
{
// 假定_customerID为客户标识
return String.Concate(unique, _customerID.ToString());
}