asp.net的缓存机制

简介: 缓存是把应用程序中的需要频繁、快速访问的数据保存在内存中的编程技术,通常用来提高网络的响应速度。在ASP.NET中使用Cache类来管理缓存。下面详述控件级数据缓存功能和页面级数据缓存功能的实现:   (1)数据库缓存依赖 数据库缓存依赖由SqlCacheDependency类管理; 数据库缓存依赖的优点: 1、提高数据呈现速度,每次获取数据后,系统根据用户设置的缓存时间,在有效期内,将数据保存在本地,用户请求数据结果时,系统不是从数据库中获取,而是直接从本地获取,从而提高了数据的获取速度。

缓存是把应用程序中的需要频繁、快速访问的数据保存在内存中的编程技术,通常用来提高网络的响应速度。在ASP.NET中使用Cache类来管理缓存。下面详述控件级数据缓存功能和页面级数据缓存功能的实现:

 

(1)数据库缓存依赖

数据库缓存依赖由SqlCacheDependency类管理;

数据库缓存依赖的优点:

1、提高数据呈现速度,每次获取数据后,系统根据用户设置的缓存时间,在有效期内,将数据保存在本地,用户请求数据结果时,系统不是从数据库中获取,而是直接从本地获取,从而提高了数据的获取速度。

2、单独缓存页面中的某一控件,而不影响其他数据的变化。为了保证页面中数据的准确性,通常只需要缓存数据控件,其他控件的数据时随时变化的。

3、数据便发生更改时,自动删除缓存项,并向Cache中添加新版本的项,这是数据库缓存依赖最重要的一个特点。

4、与SQL缓存依赖项关联的数据库操作比较简单,不会给服务器带来很高的处理成本。

 


 

实例:

(1)开启页面调试功能:

新建一个网站,点击调试(或按F5),跳出“未启用调试对话框”,默认点击“确定”(不跳出对话框则作罢)。关闭空白网页,可以看到解决资源管理器出现了web配置文件,打开,在“System.web”节点下,添加开启数据库缓存依赖的代码如下:

[xhtml]  view plain  copy
  1. <caching>  
  2.     <sqlCacheDependency enabled="true" pollTime="1000">  
  3.                   
  4.     </sqlCacheDependency>  
  5. </caching>  

 

其中:enabled属性表示是否开启数据库缓存依赖;polltime属性表示轮询数据库表的更改频率,单位:ms;不能设置小于500ms;

 

(2)配置缓存依赖的数据库

为保证数据库发生变化,应用程序能够及时更新缓存版本,必须在配置文件中指明程序所依赖的数据库,配置如下:

在web.config文件的“configuration”节点下,添加如下代码:

[c-sharp]  view plain  copy
  1. <connectionStrings>  
  2.         <remove name="JWInfoConnectionString"/>  
  3.         <add name="JWInfoConnectionString" connectionString="Data Source=.;   
  4.             Initial Catalog=JWInfo; uid=sa; pwd=123456;"  
  5.                             providerName="System.Data.SqlClient"/>  
  6. </connectionStrings>  

 

配置完数据库连接后,在启用数据库缓存依赖的配置中添加如下代码:

 

[xhtml]  view plain  copy
  1. <databases>  
  2.     <add connectionStringName="JWInfoConnectionString" name="JWInfo" pollTime="1000"/>  
  3. </databases>  

注:为防止途中出现错误,请按F5运行程序;

 

(3)为SQL SERVER启用缓存通知:

必须配置SQL SERVER才能就依赖数据中的更改向asp.ne提供合适的通知。

启用VS2005命令行(开始->程序->vs2005->vs2005 Tools->vs2005命令提示,进入DOS界面)输入:aspnet_regsql.exe,出现配置向导,进行配置;

注:为防止途中出现错误,请按F5运行程序;

 


 

控件级数据缓存功能:

 

源文件:

[xhtml]  view plain  copy
  1. <form id="form1" runat="server">  
  2.       <table>  
  3.         <tr>  
  4.           <td style="width: 362px">  
  5.             当前时间:  
  6.               <asp:Literal ID="Literal1" runat="server"></asp:Literal>  
  7.           </td>  
  8.         </tr>  
  9.         <tr>  
  10.           <td style="width: 362px">  
  11.             最后缓存时间:  
  12.               <asp:Literal ID="Literal2" runat="server"></asp:Literal>  
  13.           </td>  
  14.         </tr>  
  15.         <tr>  
  16.           <td style="width: 362px; height: 213px">  
  17.               <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px">  
  18.                   <Columns>  
  19.                       <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" />  
  20.                       <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" />  
  21.                       <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" />  
  22.                       <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" />  
  23.                   </Columns>  
  24.               </asp:GridView>  
  25.               <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>"  
  26.                   SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]"  
  27.                   CacheDuration="30" EnableCaching="true" OnSelected="SqlDataSource_Selected"></asp:SqlDataSource>  
  28.           </td>  
  29.         </tr>  
  30.       </table>  
  31.     </form>  

 

其中:CacheDuration表示缓存数据时间,单位:s,EnableCaching:表示在此数据源中是否启用缓存设置。OnSelected属性表示重新获取数据时的事件;

 

cs文件:

[c-sharp]  view plain  copy
  1. protected void Page_Load(object sender, EventArgs e)  
  2.     {  
  3.         //获取当前时间  
  4.         Literal1.Text = DateTime.Now.ToString();  
  5.   
  6.         //判断是否已经有缓存时间  
  7.         if (Cache["LastAccess"] != null)  
  8.         {  
  9.             //获取当初的缓存时间  
  10.             Literal2.Text = Cache["LastAccess"].ToString();  
  11.         }  
  12.     }  
  13.     protected void SqlDataSource_Selected(object sender, SqlDataSourceStatusEventArgs e)  
  14.     {  
  15.         //当重新获取数据时,显示当前时间  
  16.         Literal2.Text = DateTime.Now.ToString();  
  17.         //进行时间戳的缓存  
  18.         Cache["LastAccess"] = System.DateTime.Now.ToString();  
  19.     }  

 

点击“调试”运行,重复按F5,可看到效果;也可在数据有效期内修改数据库中数据观察效果;

 


 

页面级数据缓存依赖功能:

页面缓存属性在HTML代码中配置,如下:(整个页面第二行)

<%@ OutputCache Duration="20" VaryByParam="None" %>

 

其余,源文件几乎与上一个示例相同,只是去掉sqlDataSource1中的控件级缓存属性,因为这里实现的是页面缓存功能;

如下:

[xhtml]  view plain  copy
  1. <form id="form1" runat="server">  
  2.       <table>  
  3.         <tr>  
  4.           <td style="width: 362px">  
  5.             当前时间:  
  6.               <asp:Literal ID="Literal1" runat="server"></asp:Literal>  
  7.           </td>  
  8.         </tr>  
  9.         <tr>  
  10.           <td style="width: 362px">  
  11.             最后缓存时间:  
  12.               <asp:Literal ID="Literal2" runat="server"></asp:Literal>  
  13.           </td>  
  14.         </tr>  
  15.         <tr>  
  16.           <td style="width: 362px; height: 213px">  
  17.               <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="学号" DataSourceID="SqlDataSource1" Height="204px" Width="361px">  
  18.                   <Columns>  
  19.                       <asp:BoundField DataField="学号" HeaderText="学号" ReadOnly="True" SortExpression="学号" />  
  20.                       <asp:BoundField DataField="姓名" HeaderText="姓名" SortExpression="姓名" />  
  21.                       <asp:BoundField DataField="性别" HeaderText="性别" SortExpression="性别" />  
  22.                       <asp:BoundField DataField="班级编号" HeaderText="班级编号" SortExpression="班级编号" />  
  23.                   </Columns>  
  24.               </asp:GridView>  
  25.               <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:JWInfoConnectionString %>"  
  26.                   SelectCommand="SELECT [学号], [姓名], [性别], [班级编号] FROM [学生信息]" OnSelected="SqlDataSource1_Selected"></asp:SqlDataSource>  
  27.           </td>  
  28.         </tr>  
  29.       </table>  
  30.     </form>  

 

 

.cs文件:

同上一个实例的cs文件,无需改动;

 

点击“调试”运行,重复按F5,可看到效果;也可在数据有效期内修改数据库中数据观察效果;

 

所谓“依赖”:指一方发生变化后,另一方也不得不变化,这样才保证数据库中的数据和页面上显示的数据一致、同步。

实际情况可将两种机制联合使用,使页面加载速度增快!

 



原文发布时间为:2009-10-14


本文作者:vinoYang


本文来自云栖社区合作伙伴CSDN博客,了解相关信息可以关注CSDN博客。

目录
相关文章
|
2月前
|
缓存 Java 数据库连接
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
文章介绍了MyBatis的缓存机制,包括一级缓存和二级缓存的配置和使用,以及如何整合第三方缓存EHCache。详细解释了一级缓存的生命周期、二级缓存的开启条件和配置属性,以及如何通过ehcache.xml配置文件和logback.xml日志配置文件来实现EHCache的整合。
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
|
3月前
|
缓存 应用服务中间件 nginx
Web服务器的缓存机制与内容分发网络(CDN)
【8月更文第28天】随着互联网应用的发展,用户对网站响应速度的要求越来越高。为了提升用户体验,Web服务器通常会采用多种技术手段来优化页面加载速度,其中最重要的两种技术就是缓存机制和内容分发网络(CDN)。本文将深入探讨这两种技术的工作原理及其实现方法,并通过具体的代码示例加以说明。
339 1
|
3月前
|
SQL 缓存 开发框架
分享一个 .NET EF6 应用二级缓存提高性能的方法
分享一个 .NET EF6 应用二级缓存提高性能的方法
|
1月前
|
存储 缓存 负载均衡
Nginx代理缓存机制
【10月更文挑战第2天】
70 4
|
1月前
|
存储 缓存 NoSQL
深入理解后端缓存机制的重要性与实践
本文将探讨在后端开发中缓存机制的应用及其重要性。缓存,作为提高系统性能和用户体验的关键技术,对于后端开发来说至关重要。通过减少数据库访问次数和缩短响应时间,缓存可以显著提升应用程序的性能。本文将从缓存的基本概念入手,介绍常见的缓存策略和实现方式,并通过实例展示如何在后端开发中有效应用缓存技术。最后,我们将讨论缓存带来的一些挑战及其解决方案,帮助您在实际项目中更好地利用缓存机制。
|
2月前
|
存储 缓存 Android开发
Android RecyclerView 缓存机制深度解析与面试题
本文首发于公众号“AntDream”,详细解析了 `RecyclerView` 的缓存机制,包括多级缓存的原理与流程,并提供了常见面试题及答案。通过本文,你将深入了解 `RecyclerView` 的高性能秘诀,提升列表和网格的开发技能。
67 8
|
2月前
|
缓存 Java Python
python垃圾回收&缓存机制
python垃圾回收&缓存机制
|
3月前
|
缓存 NoSQL Java
【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常
【Azure Redis 缓存 Azure Cache For Redis】Redis出现 java.net.SocketTimeoutException: Read timed out 异常
|
3月前
|
缓存 NoSQL 网络协议
【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常
【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常