你的位置:首页 > 软件开发 > ASP.net > CYQ.Data V5 分布式缓存MemCached应用开发介绍

CYQ.Data V5 分布式缓存MemCached应用开发介绍

发布时间:2016-06-28 11:00:15
前言今天大伙还在热议关于.NET Core的东西,我只想说一句:在.NET 跨平台叫了这么多年间,其实人们期待的是一个知名的跨平台案例,而不是一堆能跨平台的消息。好,回头说说框架: 在框架完成数据库读写分离的功能后,开始回想起2年前所构思的:关于框架集成分布式缓存MemCac ...

前言

今天大伙还在热议关于.NET Core的东西,我只想说一句:在.NET 跨平台叫了这么多年间,其实人们期待的是一个知名的跨平台案例,而不是一堆能跨平台的消息。

好,回头说说框架: 

在框架完成数据库读写分离的功能后,开始回想起2年前所构思的:关于框架集成分布式缓存MemCached的实现。

之前一直没动手,是因为思路比较飘,秉承着框架应该简单干净轻量引用无依赖和使用不复杂的思维:

看着MemCached的服务端协议,整天思考着自己用Socket写一个客户端。

后来可能是没**,迟迟没动手。

又在某个时刻,想过偷懒,想动态反射Memcached.ClientLibrary库,但一看到它竟然关联了四个dll,我那纯洁的心就有点抗拒它了。

所以日子就这样飘来复去,这个功能被想起又遗忘......

框架集成MemCache

这几天,翻看了往昔下载的的相关源码中,有个叫BeITMemcached,扫了一下源码,发现简单轻量没外部引用。

于是就开始改造,并测试了一下,没发现问题,于是开始思考集成的方式。

框架的缓存类本来很孤单,只有一个:CacheManage.cs

现在改造完,多了10个类,编绎后dll大小多了30K,说多了也是泪~:

CYQ.Data V5 分布式缓存MemCached应用开发介绍

框架的代码重构思维

最终定案的重构思维:

1:原有的CacheManage类变更为LocalCache。

2:CacheManage类变更为抽象类

3:新增MemCache,并和LocalCache一并实现CacheManage抽象类方法。

以上三步,就是核心的思维。

一开始的重构思维:

1:从原有的CacheManage里提取接口ICache

2:CacheManage改名WebCache并继承自ICache(由于提口提取自本类,所以代码不需要怎么调整)

3:新建MemCache继承并实现ICache接口。

4:新建CacheManage类,并从WebCache处把Instance实例属性移到此类中,并返回对应的ICache接口。

编绎后发现:

因为原来的代码有一小部分是这样写的:CacheManage cache=CacheManage.Instance;

因为返回的类型不一样,原有代码受到影响,必须改成:ICache cache=CacheManage.Instance。

为了避开影响不用改动代码,所以最终改用定案里抽象类和抽象方法实现。

下面贴一下抽象类CacheManage的方法:

/// <summary>  /// 全局缓存类  /// </summary>  /// <example><code>  /// 使用示例:  /// 实例化: CacheManage cache=CacheManage.Instance;  /// 添加:  cache.Add("路过秋天",new MDataTable);  /// 判断:  if(cache.Contains("路过秋天"))  ///     {  /// 获取:    MDataTable table=cache.Get("路过秋天") as MDataTable;  ///     }  /// </code></example>  public abstract class CacheManage  {    #region 对外实例    /// <summary>    /// 返回唯一实例(根据是否配置AppConfig.Cache.MemCacheServers的服务器决定启用本地缓存或分布式缓存)    /// </summary>    public static CacheManage Instance    {      get      {        if (string.IsNullOrEmpty(AppConfig.Cache.MemCacheServers))        {          return LocalShell.instance;        }        else        {           return MemShell.instance;        }      }    }    /// <summary>    /// 单机本地缓存    /// </summary>    public static CacheManage LocalInstance    {      get      {        return LocalShell.instance;      }    }    class LocalShell    {      internal static readonly LocalCache instance = new LocalCache();    }    class MemShell    {      internal static readonly MemCache instance = new MemCache();    }    #endregion    /// <summary>    /// 添加一个Cache对象    /// </summary>    public abstract void Add(string key, object value);    public abstract void Add(string key, object value, double cacheMinutes);    public abstract void Add(string key, object value, string fileName);    public abstract void Add(string key, object value, string fileName, double cacheMinutes);    public abstract void Add(string key, object value, string fileName, double cacheMinutes, CacheItemPriority level);    public abstract Dictionary<string, CacheDependencyInfo> CacheInfo { get; }    public abstract MDataTable CacheTable { get; }    /// <summary>    /// 清除所有缓存    /// </summary>    public abstract void Clear();    public abstract bool Contains(string key);    /// <summary>    /// 获和缓存总数    /// </summary>    public abstract int Count { get; }    /// <summary>    /// 获得一个Cache对象    /// </summary>    public abstract object Get(string key);    /// <summary>    /// 获得一个Cache对象    /// </summary>    public T Get<T>(string key)    {      object o = Get(key);      if (o != null)      {        Type t = typeof(T);        try        {          return (T)StaticTool.ChangeType(o, t);        }        catch (Exception err)        {          Log.WriteLogToTxt(err);          return default(T);        }      }      return default(T);    }    /// <summary>    /// 获取目标的文件依赖是否发生更改    /// </summary>    /// <param name="key"></param>    /// <returns></returns>    public abstract bool GetFileDependencyHasChanged(string key);    /// <summary>    /// 获取缓存对象是否被手工标识为已更改    /// </summary>    /// <param name="key"></param>    /// <returns></returns>    public abstract bool GetHasChanged(string key);    /// <summary>    /// 还可用的缓存字节数    /// </summary>    public abstract long RemainMemoryBytes { get; }    /// <summary>    /// 还可用的缓存百分比    /// </summary>    public abstract long RemainMemoryPercentage { get; }    /// <summary>    /// 删除一个Cache对象    /// </summary>    public abstract void Remove(string key);    /// <summary>    /// 缓存设置:有则更新,无则添加    /// </summary>    public abstract void Set(string key, object value);    public abstract void Set(string key, object value, double cacheMinutes);    /// <summary>    /// 手动对缓存象标识为已更改    /// </summary>    public abstract void SetChange(string key, bool isChange);    /// <summary>    /// 更新缓存,缓存存在则更更新,不存在则跳过    /// </summary>    public abstract void Update(string key, object value);    public abstract string WorkInfo { get; }  }

原标题:CYQ.Data V5 分布式缓存MemCached应用开发介绍

关键词:缓存

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。