为了提升网页运行速度咱们用到了各类缓存技术,今天就来汇总下,相信聪明的你也必定会有所收获的o(^▽^)ohtml
1.Cache(PS:看见一个博客介绍的不错,我就直接Copy了)mysql
Cache 即高速缓存.那么cache是怎么样提升系统性能与运行速度呢?是否是在任何状况下用cache都能提升性能?是否是cache用的越多就越好呢?我在近 期开发的项目中有所体会,写下来看成总结也但愿能跟你们一块儿探讨探讨,有错误的地方但愿你们批评指正。
1.Cache 是怎么样工做的?
Cache 是分配在服务器上的一个公共的内存片。
所谓公共指的cache只要一建立是任何一个客户端浏览器均可以经过后台代码访问到它,它面向的是全部用户,相对而言session也是服务器上的一 段内存,但他面向的是单个用户。它是服务器的一段内存块,也就是说每一个cache一经建立就占用了服务器资源的。因此从这点来讲咱们就能够说:并非 cache越多越好。
cache 是有时间限制的,超过了服务器设定的过时时间,它就会被服务器回收。
cache 能够存听任何对象
2.Cache 怎么样建立以及怎么样销毁
建立cache
在DotNet环境下经过HttpContext.Cache.Insert(string key,object o)方法建立。
其中key 表明cache的ID,o表明存到cache里的对象。
销毁cache
经过方法HttpContext.Cache.Remove(string key)
其中key 表明cache的 ID.
调用cache
Cache支持装箱/拆箱操做。如你能够把一个DataSet对象ds经过HttpContext.Cache.Insert(“dsCache”,ds)的方式存到Cache中,能够经过拆箱操做 DataSet ds = (DataSet)Cache[“dsCache”]来访问它。
3.何时用cache
Cache 通常用于数据较固定,用的较频繁的地方。例如能够把进销存系统中能够把产品信息存入cache,在用户调用产品信息时经过调用cache便可,这样从很大 程度上减小了用户与数据库的交互,提升了系统的性能。反之,cache不适合用在数据变更快,使用范围很窄的地方。例如把一个具体采购单存入 cache中。
4.cache 调用注意事项
Cache是有时间限制的。超过了服务器设置的过时时间,就会被服务器回收。当cache被回收后对应的内存块就会被清空,再次经过cache[“cachekey”]访问对象时返回的就是null值。因此如下这种调用就会出现异常
DataSet ds = (DataSet)Cache[“cacheds”];
DataRow dr = ds.Table[0].Row[0]; //出错,ds为null值,不存在表0。
正确的写法应该是:
DataSet ds;
if(Cache[“cacheds”] != null)
{
ds = (DataSet)Cache[“cacheds”];
}
else
{
ds= GetDsFromDataBase();
}
DataRow dr = ds.Table[0].Row[0];程序员
源于:http://www.cnblogs.com/akingyao/archive/2013/01/09/2852545.html#undefinedsql
2.Memcache数据库
上面谈到的是基本的缓存,接下来谈谈分布式缓存。听着名字略叼,分布式。没事,今天咱们就搞定它~编程
笔记摘录:浏览器
//注意:使用Memcached的时候别忘了加端口号:11211 1.以Guid为key,以登陆用户为value放到mm里面去。 Guid guid=Guid.NewGuid(); -----注;CacheHelper是本身定义的类 CacheHelper.Set(guid.ToString(),userName,DateTime.Now.AddMinutes(20))//通常以20分钟过时 2.以mysessionId为key,guid为value写到Cookie里面去 Response.Cookies["mysessionId"].Value=guid.ToString(); 3.校验类:根据Cookie去查询mm里面有没有对应的值 string guid = Request["mysessionId"]; if (!String.IsNullOrEmpty(guid)) { var rec = Common.CacheHelper.Get(guid); if (rec != null) { return; } } filterContext.HttpContext.Response.Redirect("/Login/Index");
配置文件摘录:缓存
<add key="MemcachedServers" value="127.0.0.1:11211,192.168.0.101:11211" />
MmHelper.cs安全
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using Memcached.ClientLibrary; namespace HM13OA.Common { public partial class MmHelper { private MemcachedClient client; public MmHelper() { string[] ips = System.Configuration.ConfigurationManager.AppSettings["MemcachedServers"].Split(','); SockIOPool pool = SockIOPool.GetInstance(); pool.SetServers(ips); pool.Initialize(); client=new MemcachedClient(); client.EnableCompression = true; } public bool Set(string guid,object value,DateTime expiryTime) { return client.Set(guid, value, expiryTime); } public object Get(string guid) { return client.Get(guid); } public bool Delete(string guid) { return client.Delete(guid); } } }
3.Application服务器
须要在整个网站共享同一个数据能够用Application.
Application对象是HTTPApplicationState类的实例。 Application是属于全局性的对象,用于存放应用程序中多个用户共享的信息。当用户第一次访问某虚拟目录的资源时被建立,退出应用程序或关闭服务器时被撤销。
Application对象利用“键----值”对的字典方法来定义,其中“键”为字符串,表明状态的“名”,“值”能够是任何类型的数据。 例如:
Application[“message”]=”mysmg”; //给名为“message”的Application对象赋值“mysmg”
String myvar=Application[“message”] . toString() ;
// 取出名为“message”的Application的值赋给字符串 myvar
为了和ASP版本兼容,也可使用如下语句:
Application . contents[“message”]=”mysmg” ;
String myvar=Application .contents[“message”] . toString() ;
能够利用Application的add方法向Application的集合中添加项,也能够利用Remove方法删除不须要的项。例如:
Application . add(“message” , “mysmg”) ;
Application . remove(“message”) ;
能够利用clear()或者removeAll()方法清除Application集合中的内容。例如:
Application . clear() ;
Application . removeAll() ;
因为信息共享,有可能出现多个用户同时访问application时而引起的竞争。为了防止竞争带来的影响,能够利用Application对象的两个方法lock()和Unlock() 。其中lock()用于锁定对象,不容许其余进程访问; unlock()用于解锁,以便容许其余进程访问。
例如,将Application[“counter”]用来统计访问网站的人数时能够采用如下代码:
Application . lock() ; //锁定application对象,避免多用户竞争访问
Application[“counter”]=(int)Application[“counter”]+1 ;
Application . unlock() ; //解除对application对象的锁定
应用程序状态只能在网站运行时存在。 若是WEB服务器关闭或崩溃了,应用程序状态所保留的信息也会损坏或丢失 。所以,对于那些须要永久保留的状态应当保存在数据库或其余永久性的存储器中。
参考博文:http://blog.csdn.net/happylee6688/article/details/8618687
4.Cookie
cookie的特色:
1>.保存的数据量大小有限制
2>.cookie能够设置有效期。当把有效期设置为已通过期的日期,那么浏览器就会删除这个cookie
3>.当cookie比较多的时候,浏览器能够自行决定删除某些cookie
4>.用户能够直接经过浏览器清除cookie,因此在程序员编程的时候不要太依赖cookie
5>.由于cookie是存在客户端的,因此有安全性问题(不要存储密码)
6>.cookie是与域名相关的。因此在下次访问相同域名网站的时候,浏览器会自动携带该网站下的cookie一块儿访问。
7>.cookie是与浏览器相关的
8>.cookie保存数据的方式也是以键值对的方式来保存的
9>.若是写入了两个相同的键的cookie,那么后写入的会覆盖先写入的内容。
10>.通常状况下,设置cookie,都必须设置有效期,若是不设置有效期,那么这个cookie就是一个浏览器进程内的cookie(在内存中的一个cookie),因此当关闭浏览器,则cookie则当即失效
11>.能够经过服务器端使用C#语言来写cookie,也能够经过客户端JavaScript来写cookie,但不管使用哪一种方式,最终都是经过浏览器来操做的cookie
写入Cookie代码:
【写入Cookie】
//首先获取用户输入的数据
string strName = Request.QueryString["txtName"];
//建立一个HttpCookie对象
HttpCookie ck1 = new HttpCookie("user_name", strName);
ck1.Expires = DateTime.Now.AddDays(7);//设置过时时间
ck1.Path = "/";//设置在全部网页都能使用Cookie
ck1.Secure = false;
Response.Cookies.Add(ck1);//添加Cookie
【读取Cookie】
HttpCookie ck = Request.Cookies["user_name"];
Cookie具体应用请参考脚本之家:http://www.jb51.net/article/35986.htm
5.页面缓存+二级缓存
1.页面缓存:(这里主要讨论在MVC中的应用)
先说最多见的的一种:[OutputCache(Duration = 100)] ,Duration单位是秒。第一次回到了断点的地方,100秒内任意刷新都不会再执行控制器里面的A()了
带参数缓存 [OutputCache(Duration = 100, VaryByParam = "id")] [OutputCache(Duration = 100, VaryByParam = "id;name")]
上面两个缓存均写在要缓存的方法上面
2.二级缓存:(System.Web;System.Web.Caching;)
2.1绝对过时缓存
HttpRuntime.Cache.Add(key, list, null, DateTime.Now.AddSeconds(60), Cache.NoSlidingExpiration, CacheItemPriority.Default, null);
2.2相对过时缓存(有点Session的感受了)
HttpRuntime.Cache.Add(key, list, null, Cache.NoAbsoluteExpiration, new TimeSpan(0, 0, 10), CacheItemPriority.Default, null);
详情参考逆天博客:http://www.cnblogs.com/dunitian/p/6126820.html
ZJ。。。