位置:51电子网 » 技术资料 » 接口电路

Asp.net 缓存技术

发布时间:2008/8/26 0:00:00 访问次数:500

  用了缓存,其实就是由原来的:响应->执行->送显,变成: 响应->送显。中间的“执行”就省掉了,提高了效率。一般有四种类型的缓存技术。

  一.output caching

  由于iis的一些特性,默认情况下output cache是打开的,但是要对某些请求进行缓存,还需要开发者进行定制,而且默认情况下,output cache 会被缓存到硬盘上,我们可以通过修改diskcacheable的属性来设置其是否缓存,还可以通过web config里配置缓存文件的大小。

  <%@ outputcache duration="3600" varybyparam="state" diskcacheable="true" %>

  一般用硬盘缓存是考虑到页面送显的数据比较大,相对内存缓存来说,它的容量大,但是访问速度慢点,如果把周期设太短,使用硬盘缓存的效率就不大好。对于output cache的定制,有两种方法,一种是基于底层的api技术,一种是基于高层的@outputcaching:
  
  1.基于高层的@outputcaching

  a.由参数改变缓存内容:有些时候我们需要根据用户的请求来生成页面,但是用户的请求只有有限的几种组合,这个时候就可以根据用户请求来生成几种缓存页面,来进行缓存。

  <%@ outputcache duration = "60" varybyparam = "state" %>
  <asp:sqldatasource id="sqldatasource1" runat="server">
  <selectparameters>
  <asp:querystringparameter name="state" querystringfield="state" defaultvalue="ca" />
  </selectparameters>
  </asp:sqldatasource>

  b.回调缓存:可以针对每个请求在页面中插入动态的部分,以弥补单独使用静态缓存的不足:
动态的部分用substitution控件,substitution控件是一个容器

  <asp:substitution id="substitution1" runat="server" methodname ="" />

  methodname 里面放入要调用的方法内容。

  2. 使用api定制缓存:

  通过设置system.web.httpcachepolicy属性来进行配置

  <%@ outputcache duration="60" varybyparam="none" %>

  就可以写成

  response.cache.setexpires(datetime.now.addseconds(60));
  
  response.cache.setcacheability(httpcacheability.public);

  二.fragment caching

  作为output的缓存的附加功能,还提供一种缓存技术,专门用于缓存用户控件。在用户控件中设置:

  <%@ outputcache duration="60" varybyparam="none" %>

  但在引用用户控件的页面不设置缓存。这样的话,页面中除了用户控件是静态的,其他都是动态的。

  缓存用户空间同样还可以使用控件作为参数来源。通过指定控件作为缓存控件的数据来源,可以达到缓存控件数据的目的,和上面一样。

  三.data caching
  
  asp.net提供了一种非常快捷的方法进行数据库缓存,用户可以非常简单方便的对页面变量进行缓存。并以此提高程序效率。一个页面变量的缓存生命周期与应用程序的缓存生命周期相同
实现是把数据放在cache中,如:

  source = new dataview(ds);
  cache("mycache") = source;

  mycache这个变量其实就是一个xml文件。
  四.sql caching

  通过配置数据库连接池,只有当数据库数据被改变的时候,缓存才会改变。

  开个dos窗口:

  c:\>dir aspnet_regsql.exe/s ——这个文件是专门注册sql连接池的,它对sql sever 7.0以上都有专门的支持,我们通过写  一些专门的语句来配置这个注册连接池,可以把连接池和本地的应用程序(asp.net服务器,即iis)做一个连接。连接池只能监视有限的几个库,不然连接池的负载太大。使用sql caching:

  先注册,如: aspnet_regsql.exe-s".\sqlexpress"-e-d"pubs"-ed
aspnet_regsql.exe-s".\sqlexpress"-e-d"pubs"-et-t"authors"
  其中:- s".\sqlexpress" 表示要使用的sql server实例为".\sqlexpress"。-e 表示使用当前windows凭证进行身份验证。-d"pubs" 表示用于应用程序服务的数据库名称叫"pubs"。-ed表示为sql 缓存依赖项启用数据库。-et 表示为sql 缓存依赖项启用表。-t"authors"表的名称为"authors"。

  然后页面上:
  
  <%@ outputcache duration="99999999" varybyparam="none" sqldependency="pubs.authors" %>就ok了。

  欢迎转载,信息来自维库电子市场网(www.dzsc.com)



  用了缓存,其实就是由原来的:响应->执行->送显,变成: 响应->送显。中间的“执行”就省掉了,提高了效率。一般有四种类型的缓存技术。

  一.output caching

  由于iis的一些特性,默认情况下output cache是打开的,但是要对某些请求进行缓存,还需要开发者进行定制,而且默认情况下,output cache 会被缓存到硬盘上,我们可以通过修改diskcacheable的属性来设置其是否缓存,还可以通过web config里配置缓存文件的大小。

  <%@ outputcache duration="3600" varybyparam="state" diskcacheable="true" %>

  一般用硬盘缓存是考虑到页面送显的数据比较大,相对内存缓存来说,它的容量大,但是访问速度慢点,如果把周期设太短,使用硬盘缓存的效率就不大好。对于output cache的定制,有两种方法,一种是基于底层的api技术,一种是基于高层的@outputcaching:
  
  1.基于高层的@outputcaching

  a.由参数改变缓存内容:有些时候我们需要根据用户的请求来生成页面,但是用户的请求只有有限的几种组合,这个时候就可以根据用户请求来生成几种缓存页面,来进行缓存。

  <%@ outputcache duration = "60" varybyparam = "state" %>
  <asp:sqldatasource id="sqldatasource1" runat="server">
  <selectparameters>
  <asp:querystringparameter name="state" querystringfield="state" defaultvalue="ca" />
  </selectparameters>
  </asp:sqldatasource>

  b.回调缓存:可以针对每个请求在页面中插入动态的部分,以弥补单独使用静态缓存的不足:
动态的部分用substitution控件,substitution控件是一个容器

  <asp:substitution id="substitution1" runat="server" methodname ="" />

  methodname 里面放入要调用的方法内容。

  2. 使用api定制缓存:

  通过设置system.web.httpcachepolicy属性来进行配置

  <%@ outputcache duration="60" varybyparam="none" %>

  就可以写成

  response.cache.setexpires(datetime.now.addseconds(60));
  
  response.cache.setcacheability(httpcacheability.public);

  二.fragment caching

  作为output的缓存的附加功能,还提供一种缓存技术,专门用于缓存用户控件。在用户控件中设置:

  <%@ outputcache duration="60" varybyparam="none" %>

  但在引用用户控件的页面不设置缓存。这样的话,页面中除了用户控件是静态的,其他都是动态的。

  缓存用户空间同样还可以使用控件作为参数来源。通过指定控件作为缓存控件的数据来源,可以达到缓存控件数据的目的,和上面一样。

  三.data caching
  
  asp.net提供了一种非常快捷的方法进行数据库缓存,用户可以非常简单方便的对页面变量进行缓存。并以此提高程序效率。一个页面变量的缓存生命周期与应用程序的缓存生命周期相同
实现是把数据放在cache中,如:

  source = new dataview(ds);
  cache("mycache") = source;

  mycache这个变量其实就是一个xml文件。
  四.sql caching

  通过配置数据库连接池,只有当数据库数据被改变的时候,缓存才会改变。

  开个dos窗口:

  c:\>dir aspnet_regsql.exe/s ——这个文件是专门注册sql连接池的,它对sql sever 7.0以上都有专门的支持,我们通过写  一些专门的语句来配置这个注册连接池,可以把连接池和本地的应用程序(asp.net服务器,即iis)做一个连接。连接池只能监视有限的几个库,不然连接池的负载太大。使用sql caching:

  先注册,如: aspnet_regsql.exe-s".\sqlexpress"-e-d"pubs"-ed
aspnet_regsql.exe-s".\sqlexpress"-e-d"pubs"-et-t"authors"
  其中:- s".\sqlexpress" 表示要使用的sql server实例为".\sqlexpress"。-e 表示使用当前windows凭证进行身份验证。-d"pubs" 表示用于应用程序服务的数据库名称叫"pubs"。-ed表示为sql 缓存依赖项启用数据库。-et 表示为sql 缓存依赖项启用表。-t"authors"表的名称为"authors"。

  然后页面上:
  
  <%@ outputcache duration="99999999" varybyparam="none" sqldependency="pubs.authors" %>就ok了。

  欢迎转载,信息来自维库电子市场网(www.dzsc.com)



上一篇:EDA技术及软件

上一篇:ASP缓存技术

相关IC型号

热门点击

 

推荐技术资料

耳机放大器
    为了在听音乐时不影响家人,我萌生了做一台耳机放大器的想... [详细]
版权所有:51dzw.COM
深圳服务热线:13751165337  13692101218
粤ICP备09112631号-6(miitbeian.gov.cn)
公网安备44030402000607
深圳市碧威特网络技术有限公司
付款方式


 复制成功!