原文:HttpContext.Current.Cache 过期时间

为了更快的读取数据,我们一般会把常用到的数据加载到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不会

HttpContext.Current.Cache 过期时间的更多相关文章

  1. Asp.net中的Cache--HttpRuntim.Cache 和 HttpContext.Current.Cache

    在ASP.NET中有两个类都提供缓存支持, 一个是HttpRuntime类的Cache属性, 另一个是HttpContext类的Cache属性. 通过查看这两个属性的类型可以发现其实这两个属性都是Sy ...

  2. Cache及(HttpRuntime.Cache与HttpContext.Current.Cache)

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/avon520/archive/2009/11/25/4872704.aspx .NET中Cache有两种调用方式:Ht ...

  3. HttpContext.Current.Cache使用文件依赖问题

    HttpContext.Current.Cache.Insert("FCacheMs", tb, New CacheDependency(HttpContext.Current.S ...

  4. 缓存 HttpContext.Current.Cache和HttpRuntime.Cache的区别

    先看MSDN上的解释: HttpContext.Current.Cache:为当前 HTTP 请求获取Cache对象. HttpRuntime.Cache:获取当前应用程序的Cache.  我们再用. ...

  5. HttpContext.Current.Cache 和HttpRuntime.Cache的区别

    先看MSDN上的解释:      HttpContext.Current.Cache:为当前 HTTP 请求获取Cache对象.      HttpRuntime.Cache:获取当前应用程序的Cac ...

  6. HttpContext.Current.Cache 和 HttpRuntime.Cache 区别

    原文地址:http://blog.csdn.net/avon520/article/details/4872704 .NET中Cache有两种调用方式:HttpContext.Current.Cach ...

  7. HttpContext.Current.Cache 和 HttpRuntime.Cache

    HttpRuntime.Cache:用于winfrom 和 web HttpContext.Current.Cache 用于web .NET中Cache有两种调用方式:HttpContext.Curr ...

  8. HttpContext.Current.Cache和HttpRuntime.Cache的区别,以及System.Runtime.Caching

    先看MSDN上的解释:      HttpContext.Current.Cache:为当前 HTTP 请求获取Cache对象.      HttpRuntime.Cache:获取当前应用程序的Cac ...

  9. HttpRuntime.Cache 与 HttpContext.Current.Cache

    1.HttpRuntime.Cache是应用程序级别的, 2.而HttpContext.Current.Cache是针对当前WEB上下文定义的. 3.这二个都是调用的同一个对象,不同的是:HttpRu ...

随机推荐

  1. SQL Server 影响dbcc checkdb的 8 种因素

    第一种: 数据库的大小. 第二种: IO系统的速度. 第三种: 当前CPU的负荷. 第四种: 当前数据库的并发修改量.因为并发修改量越大维护数据库快照的成本就越高,dbcc 的过程中要创建快照,所以. ...

  2. U盘开发之安全U盘

    普通型安全U盘,虚拟KEY和U盘两个设备,由主机软件分别对KEY和U盘进行操作,U盘与上位机采用usb mass storage接口,KEY采用HID接口,两者均无需驱动.也有虚拟成光盘和U盘两个设备 ...

  3. Delphi利用Webbrowser登陆QQ群文档

    unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...

  4. C#调用API函数EnumWindows枚举窗口的方法

    原文 http://blog.csdn.net/dengta_snowwhite/article/details/6067928 与C++不同,C#调用API函数需要引入.dll文件,步骤如下: 1. ...

  5. 去掉ExpandableListView的箭头图标

    到ExpandableListView时有个箭头图标系统自带的在你自定义布局也不能去掉只要设置一个属性即可,如下: settingLists.setGroupIndicator(null);  ~~~ ...

  6. cf467C George and Job

    C. George and Job time limit per test 1 second memory limit per test 256 megabytes input standard in ...

  7. bzoj2014 [Usaco2010 Feb]Chocolate Buying

    Description     贝西和其他奶牛们都喜欢巧克力,所以约翰准备买一些送给她们.奶牛巧克力专卖店里 有N种巧克力,每种巧克力的数量都是无限多的.每头奶牛只喜欢一种巧克力,调查显示, 有Ci头 ...

  8. Makefile里面的$(MAKE)到底是啥

    [已解决]Makefile里面的$(MAKE)到底是啥 [复制链接] http://bbs.chinaunix.net/thread-4164499-1-1.html make 定义了很多默认变量,像 ...

  9. 8位(bit)=1字节(Byte)

    8位(bit)=1字节(Byte),1024字节=1KB: 提到了字节,不得不再提到“字”这个计量单位:“字”由若干个字节构成,字的位数叫做字长,字长就是说字所对应的二进制数的长度.不同的机器有不同的 ...

  10. DG之主库、备库切换(物理备库)

    DG之主库.备库切换 一.开库与关库顺序 开库顺序 先启备库,再启主库(启动监听.打开告警日志) 关库顺序 先关主库,再关备库 二.主备库切换 1.操作过程一览 步骤1:启动备库.监听.告警: 步骤2 ...