服务热线
153 8323 9821
缓存学术一些的解释是”将常用数据放入易于读取的地方以提高性能”。而对于Asp.net来说,需要被缓存的对象多种多样,包括从数据库中提取出来的数据,以及aspx页面生成的静态页,甚至是编译好的程序集。合理利用缓存能让Asp.net的性能大幅提升,下面将对Asp.net中的缓存机制进行简单概述。
在Asp.net中,大部分缓存机制是保存在cache对象中,也就是服务器内存的一部分。当用户请求数据时,如果数据已经被缓存,则用户所提取的数据直接从服务端返回,而不是从数据库等底层数据库提取。这对性能的提升不得不说很有帮助。下面来看asp.net中几种缓存机制。
简单的说,这种缓存是asp.net自带的,无需开发人员进行参与的缓存方式。即当第一次请求服务器时,Page类以及相关程序集被编译,当下次请求时,访问缓存后的编译而不是重新编译。CLR会自动检测代码的改变,如果代码改变后,当下次访问时,相关代码会被重新编译。
数据源缓存,顾名思义,也就是利用数据源控件对获取的数据进行缓存的方式。这些控件包括SqlDataSource,ObjectDataSource等:
作为抽象类的DataSourceControl暴漏了如下属性用于缓存:
名称 | 说明 |
CacheDuration | 获取或设置以秒为单位的一段时间,数据源控件就在这段时间内缓存 SelectMethod 属性检索到的数据。 |
CacheExpirationPolicy | 获取或设置缓存的到期行为,该行为与持续时间组合在一起可以描述数据源控件所用缓存的行为。 |
CacheKeyDependency | 获取或设置一个用户定义的键依赖项,该键依赖项链接到数据源控件创建的所有数据缓存对象。 |
EnableCaching | 获取或设置一个值,该值指示 ObjectDataSource 控件是否启用数据缓存。 |
而使用起来就非常简单了,只需要将缓存的相关属性进行设置即可。比如我想要当前数据源缓存10秒,只需要设置EnableCaching属性和CacheDuration属性如下:
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:AdventureWorksConnectionString %>" SelectCommand="SELECT top 10 * FROM [Person].[Contact]" EnableCaching="true" CacheDuration="10"></asp:SqlDataSource>
这种方式的工作原理可以用下图表示:
关于ObjectDataSource我推荐阅读Caching Data with the ObjectDataSource
大家应该注意到了上面的数据源控件还暴漏了CacheKeyDependency属性,这是用于实现SQL Cache Dependency的方式,关于Dependency,其实就是在数据库表内容改变时,将相应的缓存进行更新,正如Dependency这个词的意思一样,是缓存依赖底层数据库。下面就要说到两种实现SQL Cache Dependency的方法了。
方法一:使用轮流查询机制(polling-based):
这种方式实现机制是在sql server中插入以AspNet_SqlCacheNotification_Trigger开头的一个特殊的表和5个存储过程,当被监测的表数据发生改变时,则一个名为AspNet_SqlCacheTablesForChangeNotification的表被更新,而Asp.net程序会根据用户设置的间隔时间每隔一定时间检查一下数据库内容是否更新,如果更新,则将缓存中的数据进行跟新。
这种机制配置相对比较麻烦。具体做法网上有很多教程,这里我推荐阅读:Using SQL Cache Dependencies.
使用起来就很简单了,可以在页面头部的OutputCache指令中设置,会社DataSource空间中进行设置,设置格式为:“数据库名:表名”.里面的表名即是需要监测是否改变的表名,示例如下:
<%@ OutputCache Duration="30" VaryByParam="none" SqlDependency="DatabaseName:tableName" %>
如果需要添加多个表,则用”;”进行分割
SqlDependency="database:table;database:table"
方法二:使用通知机制(notification-based)
使用通知机制配置起来要简便很多,但是sql server的版本需要9.0以上,也就是sql server 2005,使用这种方式需要将sql server的通知服务开启。
使用通知机制可以对页面进行缓存,也可以对datasouce控件进行缓存,对页面进行缓存代码如下:
<%@ OutputCache Duration="30" VaryByParam="none" SqlDependency="CommandNotification" %>
注意SqlDependency必须设置成CommandNotification。
对于datasource控件,也是同样:
上一篇:ASP.NET页面事件执行顺序