为ASP.NET性能优化构建自定义文件缓存
现在,借助于。NET4.0中的OutputCacheProvider,我们可以有多种选择创建自己的缓存。如,我们可以把超文本标记语言输出缓存存储到服务器分布式集群服务器,或者MongoDB中(一种常用的面向文档数据库,不妨阅读本篇http://msdn。微软。com/zh-cn/magazine/gg 650661。aspx)。当然,我们也可以把缓存作为文件存储到硬盘上,考虑到可扩展性,这是一种最廉价的做法,本文就是介绍如果构建自定义文件缓存1:输出缓存提供程序是一个抽象基类,我们需要推翻其中的四个方法,它们分别是:添加方法,将指定项插入输出缓存中获取方法,返回对输出缓存中指定项的引用移除方法,从输出缓存中移除指定项设定方法,将指定项插入输出缓存中,如果该项已缓存,则覆盖该项。2:创建自己的文件缓存处理类该类型为文件缓存提供程序,代码如下:复制代码代码如下:公共类文件cacheprovider :输出cache provider { private static readonly ILog log=LogManager .系统。反射。MethodBase。GetCurrentMethod().声明类型);公共重写无效初始化(字符串名称,名称值集合属性){ base .初始化(名称、属性);CachePath=HttpContext .当前。服务器. MapPath(属性['缓存路径']);}公共覆盖对象添加(字符串键、对象条目、日期时间utc过期){对象对象=获取(键);如果(obj!=null) //这一步很重要{返回对象}集(键、条目世界协调时过期);返回条目;}公共重写对象获取(字符串键){字符串路径=ConvertKeyToPath(键);if(!文件。存在(路径)){返回null} CacheItem项=null使用(文件流文件=文件OpenRead(path)){ var formatter=new binary formatter();项目=(缓存项目)格式化程序。反序列化(文件);}如果(项到期日期=日期时间.现在。to niversaltime()){ log .信息(项目到期日期' * '键);移除(键);返回null}退货。项目;}公共覆盖无效集(字符串键,对象条目,DateTime utc过期){ CacheItem item=new CacheItem(条目,utc过期);字符串路径=ConvertKeyToPath(键);使用(文件流文件=文件OpenWrite(路径)){二进制格式化程序formatter=新的二进制格式化程序();格式化程序。序列化(文件、项目);} }公共重写移除空隙(字符串键){字符串路径=ConvertKeyToPath(键);如果(文件。存在(路径))文件。删除(路径);}公共字符串CachePath { get设置;}私有字符串ConvertKeyToPath(字符串密钥){字符串文件=密钥。替换('/','-');文件='。txt ';返回路径。组合(缓存路径,文件);} }[可序列化]公共类CacheItem {公共日期时间到期日期;公共对象项目;公共缓存项目(对象条目,DateTime utc chemistry){ Item=条目;到期日期=过期;} } 有两个地方需要特别说明:在增加方法中,有一个条件判断,必须做出这样的处理,否则缓存机制将会缓存第一次的结果,过了有效期后缓存讲失效并不再重建;在示例程序中,我们简单的将缓存放到了躲藏目录下,在实际的项目实践中,考虑到缓存的页面将是成千上万的,所以我们必须要做目录分级,否则寻找并读取缓存文件将会成为效率瓶颈,这会耗尽中央处理器.3:配置文件我们需要在Web.config中配置缓存处理程序是自定义的文件缓存提供程序,即在system.web下添加节点:复制代码代码如下:缓存输出缓存默认提供程序='文件缓存'提供程序添加名称='文件缓存'类型=' MvcApplication2 .常见。文件缓存提供程序"缓存路径="~/缓存//提供程序/输出缓存/缓存4:缓存的使用我们假设在手动音量调节的控制中使用(如果要在ASP .网页面中使用,则在页面中包含% @输出缓存VaryByParam=' none ' Duration=' 10 ' %),可以看到,索引是未进行输出缓存的,而索引2进行了输出缓存,缓存时间为10秒。
复制代码代码如下:公共类家庭控制器:控制器{私有静态只读ILog日志=日志管理器.系统。反射。MethodBase。GetCurrentMethod().声明类型);静态字符串s_conn='数据源=192 .168 .0 .77;初始目录=luminjidb用户id=Sapassword=sa ';公共操作结果索引(){使用(数据集ds=公共SqlHelper。执行数据集(s _ conn,CommandType .文本,"从名称中选择前1 *,DepTb b,其中a . Depd=b . ID ORDER BY NEWID()')){ 0视图包消息=ds .表[0]。行[0]['name'].ToString();}返回视图();} [OutputCache(Duration=10,VaryByParam=' none ')]公共操作结果索引2(){ 0使用(数据集ds=公共.SqlHelper。执行数据集(s _ conn,CommandType .文本,"从名称中选择前1 *,DepTb b,其中a . Depd=b . ID ORDER BY NEWID()')){ 0视图包消息=ds .表[0]。行[0]['name'].ToString();}返回视图();} } 5:查看下效果上面的代码,在访问了索引2后,将会在躲藏文件夹下产生缓存文件,如下
现在,我们开始评估输出缓存和非输出缓存的性能比较,并模拟来自100个用户的100个并发请求,如下所示:。
可以看出,有了输出缓存,吞吐率明显提高了10倍。6.代码下载FileCacheProvider的原始代码来自网络,我修改了其中的BUG。整个代码下载如下:MvcApplication20110907.rar。
版权声明:为ASP.NET性能优化构建自定义文件缓存是由宝哥软件园云端程序自动收集整理而来。如果本文侵犯了你的权益,请联系本站底部QQ或者邮箱删除。