zoukankan      html  css  js  c++  java
  • .NET 数据库缓存依赖策略实现

    处理大型门户网站 一般都需要 使用缓存技术这个web加速器
    在 PHP 和 java 一般 使用的是 基于squid 来做.
    当然在 windows .NET 平台也是可以的 squid有 windows版本.
    这个以后再去研究,现在 就介绍一下 .NET 自带的 缓存策略.Microsoft的petshop就用到了它;
      一、基于数据库触发(设置缓存依赖策略,当数据库中数据发生变化时,触发缓存失效;但微软提供的解决方案目前仅支持SQL Server,如果是ORACLE需要自己实现触发接口)。
      二、基于文件依赖的策略(可以设置缓存依赖于文件中的具体键值,当数据更新时,更新文件键值迫使缓存失效)。

    然后 然后 

      前面两种 当然 和 页面缓存不同. 页面缓存 可能呈现的是已经过期的内容. 而缓存策略轮询 基本上都是 最新的内容.

      下面我们来一步步的实现这个过程吧:
        首先 命令 cmd

        打开DOS 界面

    cd D:WindowsMicrosoft.NETFrameworkv2.0.50727

      注意:这里是系统安装路径.

      然后  这里我们给数据库fjmr_db设置缓存策略依赖.

    aspnet_regsql -C "Data Source=.SQLSERVER05;Integrated Security=True;Initial Catalog=fjmr_DB" -ed  

      然后 这里我们对表N_News注入依赖(当表N_News有增删改操作 就缓存失效)

    aspnet_regsql -C "Data Source=localhost;Integrated Security=True;Initial Catalog=fjmr_DB" -et -t N_News

      然后 在web.config下 配置 缓存策略节点

    复制代码
    1 <caching>
    2 <!-- 设置数据库 缓存依赖策略 轮询时间 ms 是否启用-->
    3 <sqlCacheDependency pollTime="5000" enabled="true">
    4 <databases>
    5 <!--数据库名称, 数据库链接, 轮询时间 ms-->
    6 <add name="fjmr_db" connectionStringName="数据库链接配置" pollTime="5000"/>
    7 </databases>
    8 </sqlCacheDependency>
    9
    10 </caching>
    复制代码

      配置好轮询SQL缓存依赖后,就能对页面输出缓存使用SQL依赖了。
      下面是页面缓存失效时间 9999秒! ,也就是说数据库没有更新的话9999秒都不会读库.
      当然如果数据库N_News如果更新了.那么页面就马上会刷新了!

    1 <%@ Page Language="C#" %>
    2  <%@ OutputCache Duration="9999" VaryByParam="none"
    3 SqlDependency="fjmr_db:N_News" %>

    如果希望让一个页面依赖多个数据库表,则需要将sqlDependecy特性设置为一组用分号分隔的数据库和数据库表名的列表。

    如 :fjmr_db:N_News;fjmr_db:其他表

      也可以在一个用户控件中使用<%@ OutputCache %> 指令来使用轮询SQL缓存依赖。
      也就是说,可以使用轮询SQL缓存依赖来实现部分页面缓存。
      要对SqlDataSource和ObjectDataSource控件使用轮询SQL缓存依赖,只需要设置sqlCache- Dependency属性。
      数据库名必须与配置在Web配置文件<sqlCacheDependency>元素中的数据库名相对应!

    复制代码
    <asp:SqlDataSource
    id="srcNews"
    ConnectionString
    ="<%$ ConnectionStrings:News %>"
    SelectCommand
    ="SELECT * FROM N_News"
    EnableCaching
    ="true"
    SqlCacheDependency
    ="fjmr_db:N_News"
    OnSelecting
    ="srcNews_Selecting"
    Runat
    ="server" />
    复制代码

    我们也可以对Cache对象使用轮询SQL缓存依赖,用SqlCacheDependency对象来代表一个轮询SQL缓存依赖。
      当DataTable添加到Cache时,该类就用作Cache.Insert()的一个参数。
      如果需要创建多个数据库表的依赖,
      则需要创建多个SqlCacheDependency对象并用Aggregate- CacheDependency类的实例表示多个依赖。

    复制代码
    1 DataTable news = (DataTable)Cache["_News"];
    2  if (news == null)
    3 {
    4 news = GetNewsFromDB();
    5 SqlCacheDependency sqlDepend = new
    6 SqlCacheDependency("MyDatabase", "_News");
    7 Cache.Insert("_News", news, sqlDepend);
    8 }
    9 grdNews.DataSource = news;
    10 grdNews.DataBind();
    11 }
    复制代码

      最后 这种缓存策略只适用于一般 中小型的 缓存加速. 如果对大型系统 做的话 很多时候是用到了 NoSQL技术,分布式缓存服务器.

  • 相关阅读:
    【数据结构栈应用系列】括号匹配
    【二叉树系列】二叉树课程大作业
    Tomcat在Linux上的安装与配置
    索引介绍及创建与删除索引
    Java 内存溢出(java.lang.OutOfMemoryError)的常见情况和处理方式总结
    Tomcat的配置文件server.xml叙述
    问题及解决方法
    Oracle DB 查看预警日志
    报表简介
    Nginx负载均衡与反向代理—《亿级流量网站架构核心技术》
  • 原文地址:https://www.cnblogs.com/ajunForNet/p/4332257.html
Copyright © 2011-2022 走看看