zoukankan      html  css  js  c++  java
  • .Net Cache及(HttpRuntime.Cache与HttpContext.Current.Cache的区别)

    因为程序中用到 在当前会话上下文中缓存多个数据库的需求,所有查了下资料。

    我们在.NET运用中经常用到缓存(Cache)对象。
    除了System.Web.Caching下的Cache外,我们还可以用到HttpContext.Current.Cache以及HttpRuntime.Cache
    那么,HttpContext.Current.Cache以及HttpRuntime.Cache有什么区别呢?
    从MSDN上的解释可以看出,HttpRuntime.Cache是应用程序级别的,而HttpContext.Current.Cache是针对当前WEB上下文定义的。
    然而,实际上,这二个都是调用的同一个对象,不同的是:HttpRuntime下的除了WEB中可以使用外,非WEB程序也可以使用。
    而HttpContext则只能用在WEB中。

    因此,在可能的情况下,我们尽可能使用HttpRuntime(然而,在不同应用程序之间如何调用也是一个问题)。

    了更快的读取数据,我们一般会把常用到的数据加载到Cache中 
    
    在.NET中,Cache的存在可以依赖多中方式,主要用到HttpContext.Current.Cache类 
    
    在这里,我主要写几种依赖方式 
    
    1:不依赖任何条件 
    
    HttpContext.Current.Cache.Insert(string cacheName,object obj) 
    
    理论上是Cache会永久保存,但是当服务器重新启动,内存紧张的时候也会丢失. 
    
    2:HttpContext.Current.Cache.Insert(string key, object value, CacheDependency dependencies, DateTime absoluteExpiration, TimeSpan slidingExpiration); 
    
    //CacheDependency缓存依赖项,absoluteExpiration绝对过期时间,slidingExpiration最后一次访问的时间隔 
    
    //我们主要讲两种Cache依赖 
    
    2.1:文件依赖,so simple//只要文件改动,Cache移出 
    
    HttpContext.Current.Cache.Insert(cacheName,ojb, new System.Web.Caching.CacheDependency(FilePath)); 
    
    2.2:SqlServer数据库依赖//我这里是SQL2005 
    
    首先看数据库通知是否可用,记得一定要开启通知 
    
    Select DATABASEpRoPERTYEX('数据库名','IsBrokerEnabled');如果值为1表示可用 
    
    alter database Game176Admin set ENABLE_BROKER ;//开启
    alter database Game176Admin set DISABLE_BROKER;//关闭 
    
    在Global.asax文件中,我们在应用程序开始和结束时要做一些事情 
    
    void Application_Start(object sender, EventArgs e)
    {
    // 在应用程序启动时运行的代码
    try
    {
    System.Data.SqlClient.SqlDependency.Start(string strCon);//开启
    }
    catch { }
    } 
    
    void Application_End(object sender, EventArgs e)
    {
    // 在应用程序关闭时运行的代码
    try
    {
    System.Data.SqlClient.SqlDependency.Stop(string strCon);
    }
    catch { }
    } 
    
    准备工作已经完成 
    
    我们先写一个方法,添加数据库依赖 
    
    void AddSqlDependency(string strCon, string strSql, OnChangeEventHandler sqlDep_OnChange)
    {
    try
    {
    using (SqlConnection conn = new SqlConnection(strCon))
    {
    SqlCommand comm = new SqlCommand(strSql, conn);
    SqlDependency sqlDep = new SqlDependency(comm);
    sqlDep.OnChange += sqlDep_OnChange;
    if (conn.State == ConnectionState.Closed) conn.Open();
    comm.ExecuteNonQuery();
    }
    }
    catch (Exception ex)
    {
    LogUtility.Add(ex);
    }
    } 
    
    //上面这个方法是告诉数据库,当你指定表数据改变,要移出缓存 
    
    我们现在可以来添加了 
    
    MyObject obj= HttpRuntime.Cache["cacheName"] as MyObject;
    if (null == obj)
    {
    try
    {
    obj= GetObj(...);
    }
    catch (Exception ex)
    {
    LogUtility.Add(ex);
    obj= null;
    }
    if (null != obj)
    {
    AddSqlDependency(strCon, "select id from dbo.tableName;select id1 from dbo.tableName1",
    delegate(object sender, SqlNotificationEventArgs e)
    {
    //do something 
    
    HttpRuntime.Cache.Remove("cacheName");
    });
    HttpRuntime.Cache.Insert("cacheName", obj);
    }
    } 
    
    上面SQL语句中用到的表,只要这些表中的任何数据有改动,数据库都会通知,这时缓存会移动,select的字段和Cache没有关系,只有表名有关系,所有你要选择最小的字段.很多时候,为了这个字段,在设计表的时候都为多加一个最小的依赖列. 
    
    NOTE:任何Cache都可能丢失,使用前一定要做必要的检查,如: 
    
    MyObject obj=HttpContext.Current.Cache("CacheName") as MyObject; 
    
    if(null==obj) 
    
    { 
    
    obj=....... 
    
    HttpContext.Current.Cache.Insert("CacheName",obj); 
    
    }
    Cache用法之页面声明 
    
    <%@ outputCache
    Duration="#ofseconds"
    Location="Any|Client|Downstream|Server|None"
    VaryByControl="ControlName"
    VaryByCustom="browser|customstring"
    VaryByHeader="headers"
    VaryByParam="Parametername" %> 
    
    Cache用法之代码控制
    HttpCachePolicy类是专门用来控件Cache的,可以用Response.Cahce来访问这个类的实例 
    
    Response.Cache.SetExpires(DateTime.Now.AddSeceonds(10));
    Response.Cache.SetCacheability(HttpCacheablility.Public);
    Response.Cache.SetValidUnitlExpires(true); 
    
    -----------------------以上都是缓存页面的,下面是缓存数据的----------------------------
    Cache 类的生存周期等于应用程序的生命周期
    三种用法
    1:存:Cache["key"] = MyData;取:
    MyData = Cache["key"];
    if(MyData != null)
    use(MyData);
    此法存入Cache的数据生命周期等于应用程序生命周期,不支持清除、过期、依赖性等功能。 
    
    2:存:
    Cache.Insert(
    string key,
    object value,
    CacheDependency dependencies,//依赖,设置缓存有效的依赖性,比如设置和一个文件相关,文件一变,就失效
    DateTime absoluteExpireation, //设置固定的过期时间
    TimeSpan slidingExpiration, //设置最后一次访问后多长时间过期
    CachePriority priority, //设置内存不足,缓存自动清除时,缓存的重要性,可不可以清除
    CacheItemRemovedCallback onRemoveCallback // 设置在清除时引发的事件
    )
    Example: 
    
    Cache.Insert("Mydata",MyData,new Caching.CacheDependency(Server.MapPah("Mydata.XML")));//设置有效性和一个文件有关
    Cache.Insert("Mydata",myData,null,DateTime.Now.AddDays(1),Cache.NoSlidingExpiratin);//两种过期时间设了其中一种,另一种要设为0,用NoAbsolute(Sliding)Expiration枚举
    Cache.Insert("MyData",myData,null,Cache.NoAbsoluteExpiration,TimeSpan.FromMinutes(10));//不能过一年不能小于0
    Cache.Insert("MyData",myData,null,Cache.NoAbsoluteExpiration,TimeSpan.FromMinutes(10),
    Caching.CacheItemPriority.NotRemovable,null);
    // AboveNormal|BelowNormal|Default|High|Low|Normal|NotRemovable
    
    public void RemovedCallback(string key,object value,CacheItemRemovedReason reason)
    {
    if(reason == CacheItemRemovedReason.DependencyChanged)
    Response.Write("文件变了,快去看看");
    }
    Cache.Insert("Mydata",MyData,new Caching.CacheDependency(Server.MapPah("Mydata.XML"),
    DateTime.Now.AddDays(1),Cache.NoSlidingExpiration,CacheItemPriority.High,
    new CacheItemRemovedCallback(this.RemovedCallback)); 
    
    清除就可以用Cache.Remove("key");方法 
    
    3:
    Cache.Add方法,用法和Insert差不多,区别在于Add碰到该key原来有赋过值会失败,Insert则不会,而会替换原有值;Add会返回被缓存数据项,Insert不会
  • 相关阅读:
    网络编程1:网络模型
    window10解决需要管理员删除文件的权限问题
    嵌入式框架iframe
    布局框架frameset
    JDBC连接mysql
    springboot插件
    Win10安装 oracle11g 出现INS-13001环境不满足最低要求解决方法
    卸载虚拟机
    Maven
    mysql-数据备份与还原
  • 原文地址:https://www.cnblogs.com/zhuimengzhe/p/6651428.html
Copyright © 2011-2022 走看看