【Cache】Asp.Net Cache缓存讲解与使用代码

分类:.Net知识问答| 发布:camnprbubuol| 查看: | 发表时间:2010/9/25

相比ASP.NET的所有其他特性,缓存对应用程序的性能具有最大的潜在影响,利用缓存和其他机制,ASP.NET 开发人员可以接受使用开销很大的控件(例如,DataGrid)构建站点时的额外开销,而不必担心性能会受到太大的影响。为了在应用程序中最大程度地利用缓存,您应该考虑在所有程序级别上都实现缓存的方法。

  实现

  要实现页面输出缓存,只要将一条 OutputCache 指令添加到页面即可。

  <%@ OutputCache Duration="60" VaryByParam="*" %>

  如同其他页面指令一样,该指令应该出现在 ASPX 页面的顶部,即在任何输出之前。它支持五个属性(或参数),其中两个是必需的。

  Duration

  必需属性。页面应该被缓存的时间,以秒为单位。必须是正整数。

  Location

  指定应该对输出进行缓存的位置。如果要指定该参数,则必须是下列选项之一:Any、Client、Downstream、None、Server 或 ServerAndClient。

  VaryByParam

  必需属性。Request 中变量的名称,这些变量名应该产生单独的缓存条目。"none" 表示没有变动。"*" 可用于为每个不同的变量数组创建新的缓存条目。变量之间用 ";" 进行分隔。

  VaryByHeader

  基于指定的标头中的变动改变缓存条目。

  VaryByCustom

  允许在 global.asax 中指定自定义变动(例如,"Browser")。

  利用必需的 Duration 和 VaryByParam 选项的组合可以处理大多数情况。例如,如果您的产品目录允许用户基于 categoryID 和页变量查看目录页,您可以用参数值为 "categoryID;page" 的 VaryByParam 将产品目录缓存一段时间(如果产品不是随时都在改变,一小时还是可以接受的,因此,持续时间是 3600 秒)。这将为每个种类的每个目录页创建单独的缓存条目。每个条目从其第一个请求算起将维持一个小时。

  VaryByHeader 和 VaryByCustom 主要用于根据访问页面的客户端对页面的外观或内容进行自定义。同一个 URL 可能需要同时为浏览器和移动电话客户端呈现输出,因此,需要针对不同的客户端缓存不同的内容版本。或者,页面有可能已经针对 IE 进行了优化,但需要能针对 Netscape 或 Opera 完全降低优化(而不仅仅是破坏页面)。后一个例子非常普遍,我们将提供一个说明如何实现此目标的示例:

  示例:VaryByCustom 用于支持浏览器自定义

  为了使每个浏览器都具有单独的缓存条目,VaryByCustom 的值可以设置为 "browser"。此功能已经内置在缓存模块中,并且将针对每个浏览器名称和主要版本插入单独的页面缓存版本。

  <%@ OutputCache Duration="60" VaryByParam="None" VaryByCustom="browser" %>

  片段缓存,用户控件输出缓存

  缓存整个页面通常并不可行,因为页面的某些部分是针对用户定制的。不过,页面的其他部分是整个应用程序共有的。这些部分最适合使用片段缓存和用户控件进行缓存。菜单和其他布局元素,尤其是那些从数据源动态生成的元素,也应该用这种方法进行缓存。如果需要,可以将缓存的控件配置为基于对其控件(或其他属性)的更改或由页面级输出缓存支持的任何其他变动进行改变。使用同一组控件的几百个页面还可以共享那些控件的缓存条目,而不是为每个页面保留单独的缓存版本。

  实现

  片段缓存使用的语法与页面级输出缓存一样,但其应用于用户控件(.ascx 文件)而不是 Web 窗体(.aspx 文件)。除了 Location 属性,对于 OutputCache 在 Web 窗体上支持的所有属性,用户控件也同样支持。用户控件还支持名为 VaryByControl 的 OutputCache 属性,该属性将根据用户控件(通常是页面上的控件,例如,DropDownList)的成员的值改变该控件的缓存。如果指定了 VaryByControl,可以省略 VaryByParam。最后,在默认情况下,对每个页面上的每个用户控件都单独进行缓存。不过,如果一个用户控件不随应用程序中的页面改变,并且在所有页面都使用相同的名称,则可以应用 Shared="true" 参数,该参数将使用户控件的缓存版本供所有引用该控件的页面使用。

  示例

  <%@ OutputCache Duration="60" VaryByParam="*" %>

  该示例将缓存用户控件 60 秒,并且将针对查询字符串的每个变动、针对此控件所在的每个页面创建单独的缓存条目。

  <%@ OutputCache Duration="60" VaryByParam="none"

  VaryByControl="CategoryDropDownList" %>

  该示例将缓存用户控件 60 秒,并且将针对 CategoryDropDownList 控件的每个不同的值、针对此控件所在的每个页面创建单独的缓存条目。

  <%@ OutputCache Duration="60" VaryByParam="none" VaryByCustom="browser"

  Shared="true %>

  最后,该示例将缓存用户控件 60 秒,并且将针对每个浏览器名称和主要版本创建一个缓存条目。然后,每个浏览器的缓存条目将由引用此用户控件的所有页面共享(只要所有页面都用相同的 ID 引用该控件即可)。

  页面级和用户控件级输出缓存的确是一种可以迅速而简便地提高站点性能的方法,但是在 ASP.NET 中,缓存的真正灵活性和强大功能是通过 Cache 对象提供的。使用 Cache 对象,您可以存储任何可序列化的数据对象,基于一个或多个依赖项的组合来控制缓存条目到期的方式。这些依赖项可以包括自从项被缓存后经过的时间、自从项上次被访问后经过的时间、对文件和/或文件夹的更改以及对其他缓存项的更改,在略作处理后还可以包括对数据库中特定表的更改。

  在 Cache 中存储数据

  在 Cache 中存储数据的最简单的方法就是使用一个键为其赋值,就像 HashTable 或 Dictionary 对象一样:

  Cache["key"] = "value";

  这种做法将在缓存中存储项,同时不带任何依赖项,因此它不会到期,除非缓存引擎为了给其他缓存数据提供空间而将其删除。要包括特定的缓存依赖项,可使用 Add() 或 Insert() 方法。其中每个方法都有几个重载。Add() 和 Insert() 之间的唯一区别是,Add() 返回对已缓存对象的引用,而 Insert() 没有返回值(在 C# 中为空,在 VB 中为 Sub)。

  示例

  Cache.Insert("key", myXMLFileData, new

  System.Web.Caching.CacheDependency(Server.MapPath("users.xml")));

  该示例可将文件中的 xml 数据插入缓存,无需在以后请求时从文件读取。 CacheDependency 的作用是确保缓存在文件更改后立即到期,以便可以从文件中提取最新数据,重新进行缓存。如果缓存的数据来自若干个文件,还可以指定一个文件名的数组。

  Cache.Insert("dependentkey", myDependentData, new

  System.Web.Caching.CacheDependency(new string[] {}, new string[]

  {"key"}));

  该示例可插入键值为 "key" 的第二个数据块(取决于是否存在第一个数据块)。如果缓存中不存在名为 "key" 的键,或者如果与该键相关联的项已到期或被更新,则 "dependentkey" 的缓存条目将到期。

  Cache.Insert("key", myTimeSensitiveData, null,

  DateTime.Now.AddMinutes(1), TimeSpan.Zero);

web.config里可以这么配置:

 <caching>
   <outputCacheSettings>
    <outputCacheProfiles>
     <add name="PageCache" duration="60" varyByParam="none" enabled="true"/>
    </outputCacheProfiles>
   </outputCacheSettings>
  </caching>

代码如下:

public DataSet createCache() 
{ 
//返回DataSet 
DataSet ds=new DataSet(); 
OleDbConnection conn=new OleDbConnection("provider=microsoft.jet.oledb.4.0;data source="+Server.MapPath("data.mdb")); 
conn.Open(); 
string sql="select * from data1 order by createtime asc"; 
OleDbDataAdapter cmd=new OleDbDataAdapter(sql,conn); 
cmd.Fill(ds); 
cmd.Dispose(); 
conn.Dispose(); 
return ds; 
} 

private void Button1_Click(object sender, System.EventArgs e) 
{ 
//清除Cache 
Cache.Remove("DataList"); 
Response.Write("缓存清除成功"); 
} 

private void Button2_Click(object sender, System.EventArgs e) 
{ 
//建立Cache 
if(Cache["DataList"]==null) 
{ 
//缓存不存在建立缓存 
Cache.Insert("DataList",(DataSet)createCache()); 
DataSet ds=(DataSet)Cache["DataList"]; 
DataGrid1.DataSource=ds; 
DataGrid1.DataBind(); 
} 
else 
{ 
//缓存存在执行绑定 
DataSet ds=(DataSet)Cache["DataList"]; 
DataGrid1.DataSource=ds; 
DataGrid1.DataBind(); 
} 
}
365据说看到好文章不转的人,服务器容易宕机
原创文章如转载,请注明:转载自郑州网建-前端开发 http://camnpr.com/
本文链接:http://camnpr.com/net-wiki/44.html

相关文章