zoukankan      html  css  js  c++  java
  • Cache、它和Redis区别是什么???

    前言:今天在博客园看到大佬在用Cache,非常不懂,原来它是搞缓存的,原来我只知道Redis是搞这个的,才知道有这个玩腻。

      那它们的区别是什么呢?? 区别: redis是分布式缓存,是将数据随机分配到不同服务器的,catch属于单机缓存,只能本机访问。

    那Cache是如何工作的呢?

    所谓公共指的cache只要一创建是任何一个客户端浏览器都可以通过后台代码访问到它,它面向的是所有用户,相对而言session也是服务器上的一 段内存,但他面向的是单个用户。它是服务器的一段内存块,也就是说每个cache一经创建就占用了服务器资源的。所以从这点来说我们就可以说:并不是 cache越多越好。cache 是有时间限制的,超过了服务器设定的过期时间,它就会被服务器回收。cache 可以存放任何对象。

    如何操作Cache??

    创建:在DotNet环境下通过Cache.Insert(string key,object o)方法创建。其中key 代表cache的ID,o代表存到cache里的对象。

    销毁cache:通过方法Cache.Remove(string key), 其中key 代表cache的 ID.

    调用cache:Cache支持装箱/拆箱操作。如你可以把一个DataSet对象ds通过Cache.Insert(“dsCache”,ds)的方式存到Cache中,可以通过拆箱操作 DataSet ds = (DataSet)Cache[“dsCache”]来访问它。

    最后附大佬封装好的帮助类一份:

    C#/CacheHelper:

    using System;  
    using System.Web;  
    using System.Collections;  
    using System.Web.Caching;  
      
    public class CacheHelper  
    {  
        /// <summary>  
        /// 获取数据缓存  
        /// </summary>  
        /// <param name="cacheKey">键</param>  
        public static object GetCache(string cacheKey)  
        {  
            var objCache = HttpRuntime.Cache.Get(cacheKey);  
            return objCache;  
        }  
        /// <summary>  
        /// 设置数据缓存  
        /// </summary>  
        public static void SetCache(string cacheKey, object objObject)  
        {  
            var objCache = HttpRuntime.Cache;  
            objCache.Insert(cacheKey, objObject);  
        }  
        /// <summary>  
        /// 设置数据缓存  
        /// </summary>  
        public static void SetCache(string cacheKey, object objObject, int timeout = 7200)  
        {  
            try  
            {  
                if (objObject == null) return;  
                var objCache = HttpRuntime.Cache;  
                //相对过期  
                //objCache.Insert(cacheKey, objObject, null, DateTime.MaxValue, timeout, CacheItemPriority.NotRemovable, null);  
                //绝对过期时间  
                objCache.Insert(cacheKey, objObject, null, DateTime.Now.AddSeconds(timeout), TimeSpan.Zero, CacheItemPriority.High, null);  
            }  
            catch (Exception)  
            {  
                //throw;  
            }  
        }  
        /// <summary>  
        /// 移除指定数据缓存  
        /// </summary>  
        public static void RemoveAllCache(string cacheKey)  
        {  
            var cache = HttpRuntime.Cache;  
            cache.Remove(cacheKey);  
        }  
        /// <summary>  
        /// 移除全部缓存  
        /// </summary>  
        public static void RemoveAllCache()  
        {  
            var cache = HttpRuntime.Cache;  
            var cacheEnum = cache.GetEnumerator();  
            while (cacheEnum.MoveNext())  
            {  
                cache.Remove(cacheEnum.Key.ToString());  
            }  
        }  
    }

    为此我们测试以下:

     public List<string> GetCompanyList()
            {
                var cache = CacheHelper.GetCache("Company_List");
                if (cache == null)//如果不存在
                {
                    //var queryCompany = _Project_BLL_GetCompanyList;
                    var queryCompany = new List<string>()
                    {
                        "Zara博客工作室","中国网银","博客园"
                    };
                    CacheHelper.SetCache("companyData",queryCompany);//添加缓存
                    return queryCompany.ToList();
                }
                return (List<string>)cache; //如果有的话就直接返回了
            }
  • 相关阅读:
    【SqlServer系列】表达式(expression)
    【SqlServer系列】语法定义符号解析
    Docker常用命令<转>
    VMware下的Centos7联网并设置固定IP
    redis的setbit命令
    Java并发编程:并发容器之CopyOnWriteArrayList<转>
    Java并发编程:volatile关键字解析<转>
    Java并发编程:阻塞队列 <转>
    Java并发编程:Lock和Synchronized <转>
    Jackson学习笔记(三)<转>
  • 原文地址:https://www.cnblogs.com/ZaraNet/p/9922825.html
Copyright © 2011-2022 走看看