我用ASP.NET缓存之SQL数据缓存依赖(SqlCacheDependency)

【名词解释】

缓存(Cache)依赖,大白话解释就是缓存是否更新依赖于其它Object。那么SqlCacheDependency指的就是Cache的数据更新依赖于SQL Server数据库表的变化( 行级别更改)或者SQL 查询结果的变化。

以前也总结过缓存的使用

页面输出缓存:我用ASP.NET缓存之OutputCache

数据缓存:我用ASP.NET缓存之数据缓存

但是对缓存依赖还是很模糊,前阵子有幸在项目中实际运用了此类。现在结合自己的实际以及和网上大牛的经验,给大家分享一下。

【使用背景】

首先你必须用ASP.Net和SQL Server开发应用,也就是SqlCacheDependency是基于微软的那套体制。同学,如果你不是从事Net开发,先给个赞再Skip吧。

缓存是用来提高应用性能,降低服务器压力。适用于数据不易变,数据易通用的情景, 对于动态查询数据,例如数据分析,最好放弃使用缓存。

【我的代码】

SqlCacheDependency通俗的说利用SQL Server的通信机制,当数据表发生变化时,通知应用程序时删除原有的缓存,更新新的数据。

首先需要检查SqlServer是否启用Service Broker。

Select DATABASEpRoPERTYEX(‘数据库名称‘,‘IsBrokerEnabled‘)          -- 1 表示已经启用 0 表示没有启用

启用语句

ALTER DATABASE 数据库名称 SET ENABLE_BROKER;

运行启用语句,会出现假死情况,不要紧,停止查询,重新查询一次就可以。

上面这些来自于网上的一些经验,个人在实际中并没有出现这些情况,状态=0 ,仍然可以使用。我用的是SQL Serve2008,个人觉得高版本的Sql Server 已经不在将这些作为必须条件(个人观点,不同意见,欢迎讨论)。毕竟Net开发走的是一条傻瓜化编程道路。

接下来就是配置数据库缓存通知。两种方法(MSDN),个人建议采用第二种。

第一种利用aspnet_regsql.exe(位于Windows\Microsoft.NET\Framework\[版本]文件夹中) 工具配置数据库和表开启缓存通知功能。你只需要记住如下命令就能开启:

aspnet_regsql -S localhost -E -d RWWW -ed -t Options -et

每个命令代表什么含义,网上有详细的解释。有兴趣的同学可以去了解。运行命令后,配置就可以。这里特别需要注意大小写,笔者在开发中就将表名全部弄成大写,结果花了一个小时的时间,程序始终运行不起来,一直在报错,提示没有为SQL缓存通知启用数据库。结果最后才发现大小写不对。

第二种就是利用SqlCacheDependencyAdmin类

SqlCacheDependencyAdmin.EnableNotifications(connectionString);     //启动数据库的数据缓存依赖功能

SqlCacheDependencyAdmin.EnableTableForNotifications(connectionString, table);        //启用数据表缓存

将此两行代码放入Global中Start方法中即可。

接下来配置配置文件。

<caching>
      <!--启动缓存依赖,每5秒轮询一次-->
      <sqlCacheDependency enabled="true" pollTime="5000">
        <databases>
          <add name="WWWAccount" connectionStringName="ConnectionString" pollTime="5000"/>
        </databases>
      </sqlCacheDependency>
    </caching>

这里基本就是固定格式,必须这样配置才可以。

最后将缓存加入代码中即可,废话不多说,直接上代码。开发中用到了EF的东东。

//判断是否已缓存
                if (System.Web.HttpContext.Current.Cache["Link"] == null)
                {
                    //如果没有缓存 重新获取数据
                    var links = db.WWW_Link.AsQueryable();
                    //添加到缓存中
                    System.Web.HttpContext.Current.Cache.Insert(
                        "Link",
                        links,
                        new SqlCacheDependency("WWWAccount", "WWW_Link")
                        );
                    //返回数据
                    return links;
                }
                //如果已经缓存 返回缓存数据
                return System.Web.HttpContext.Current.Cache["Link"] as IQueryable<WWW_Link>;

当表WWW_Link发生变化时,Cache["Link"]会自动更新。这里主意SqlCacheDependency 的第一个参数,它等于App.config中节点name=WWWAccount。

时间: 2024-12-24 05:46:40

我用ASP.NET缓存之SQL数据缓存依赖(SqlCacheDependency)的相关文章

cache应用(asp.net 2.0 SQL数据缓存依赖 [SqlCacheDependency ] )

Asp.net 2.0 提供了一个新的数据缓存功能,就是利用sql server2005 的异步通知功能来实现缓存 1.首先在sqlserver2005 中创建一个test的数据库. 在SQL Server 2005上执行 ALTER DATABASE <DatabaseName> SET ENABLE_BROKER;语句让相应的数据库启用监听服务,以便支持SqlDependency特性. 添加一个 employee的数据库表. 1CREATETABLE[dbo].[employee](2[i

Yii的缓存机制之数据缓存

具体说法就是可以缓存变量信息. 设置:Yii::app()->cache->set(名字, 值, 过期时间): 使用:Yii::app()->cache->get(名字); 删除:Yii::app()->cache->delete(名字); 清空:Yii:app()->cache->flush(); 缓存数据的应用: 用来缓存数据:可以在数据模型里自定义一个方法,来获取自己想要的数据然后进行缓存 例如获取商品的详细信息时,在Goods模型了里自定义一个获取商

web开发人员须知的web缓存知识–将数据缓存到浏览器端Net实现

现实中,服务器在向浏览器发送的数据中,一部分数据是不经常更新的,如果能将这部分数据缓存到浏览器端,将会大大降低传输的数据,提高应用的性能.通过Expires策略,可以使用HTTP 协议定义的缓存机制将数据缓存到浏览器中.下面我们看看Net是如何实现将数据缓存到浏览器中的. protected void Page_Load(object sender, EventArgs e) { if (Request.Headers["If-Modified-Since"] != null &

SQL数据缓存依赖

1:打开项目配置文件 2:启动数据库缓存依赖 aspnet_regsql -C "data source=;initial catalog=codematic;user id=sa;password=" -ed -et -t "T_table" 3:使用缓存依赖项 4:实际的生产环境中如何应用? 原文地址:http://blog.51cto.com/11871779/2092423

【缓存】Sql Server 2005/2008 SqlCacheDependency查询通知的使用总结

Sql server 7.0/2000下 SqlCacheDependency使用轮询的方式进行缓存失效检查, 虽然ms说对服务器压力不大, 但还是有一些的, 而且对于不常改动的混存内容无休止的轮询感觉有点浪费, 不很经济. Sql server 2005/2008下增加使用查询通知方式进行缓存失效检查, 它通过Sql Server内部的消息队列进行异步通知, 这样就大大减轻了服务器的压力, 实现的很经济, 下面就是具体的步骤: 1.检测是否已经启用Service Broker Select D

SQL Server 数据缓存

引言 SQL Server通过一些工具来监控数据,其中之一的方法就是动态管理管理视图(DMV). 常规动态服务器管理对象 dm_db_*:数据库和数据库对象 dm_exec_*:执行用户代码和关联的连接 dm_os_*:内存.锁定.时间安排 dm_tran_*:事务和隔离 dm_io_*:网络和磁盘输入输出 数据缓存 对于当前数据缓存中每个数据库的缓存大小情况,可以使用如下DMV来查询,sys.dm_os_buffer_descriptiors select COUNT(*)*8/1024 as

【ASP.NET 系列】浅谈缓存技术在ASP.NET中的运用

本篇文章虽不谈架构,但是Cache又是架构中不可或缺的部分,因此,在讲解Cache的同时,将会提及到部分架构知识,关于架构部分,读者可以不用理解,或者直接跳过涉及架构部分的内容, 你只需关心Cache即可,具体的架构,会在后续文章中与大家分享,如果你感兴趣,只需关注即可. 一   为什么要在ASP.NET 项目中引入缓存 1. 我们先来考虑一个问题,通常,面临高并发问题时,我们应该怎么处理? 下图为常规的处理思路和方法 2.为什么引入Cache呢? 我们知道,造成高并发的根本原因是大量读写的问题

jQuery源代码学习之六——jQuery数据缓存Data

一.jQuery数据缓存基本原理 jQuery数据缓存就两个全局Data对象,data_user以及data_priv; 这两个对象分别用于缓存用户自定义数据和内部数据: 以data_user为例,所有用户自定义数据都被保存在这个对象的cache属性下,cache在此姑且称之为自定义数据缓存: 自定义数据缓存和DOM元素/javascript对象通过id建立关联,id的查找通过DOM元素/javascript元素下挂载的expando属性获得 话不多说,直接上代码.相关思路在代码注释中都有讲解

jQuery数据缓存data(name, value)详解及实现

一. jQuery数据缓存的作用 jQuery数据缓存的作用在中文API中是这样描述的:“用于在一个元素上存取数据而避免了循环引用的风险”.如何理解这句话呢,看看我下面的举例,不知道合不合适,如果你有更好的例子可以告诉我. (1) 存在循环引用风险的例子(注意getDataByName(name)方法中的for in语句): <a href="javascript:void(0);" onclick="showInfoByName(this.innerHTML);&qu