Memcached快递上手之C#

C# 操作Memcached

Memcached是开源高性能分布式缓存组件,目前已经广泛应用各类互联网领域. 具有多种语言的客户端开发包,包括:Perl/PHP/JAVA/C/Python/Ruby/C#/MySQL. 这此站点已经在使用YouTube,Reddit,Zynga,Facebook,Orange它. 看
下面的图比较形象.

MemcachedEffect

 

       同样它也是扩平台的,今天我们来看windows下的服务端以及使用.net的客户端访问它.我们
选择了Enyim Memcached这个客户端. 
      首先,我们安装windows版的服务端,你可以从这个站点下载. 安装时使用命令行:

memcached.exe –d install

这样将Windows service中创建一个memcached的服务. 同样你可以使用 –d uninstall 来卸载它. 运行时将默认监听11211
IP:127.0.0.1,如下图所示:
memcache1

要在nuget里引用(安装) EnyimMemcached ,下面是以调用阿里云的ocs(memcached)服务为例

[csharp]  view plain  copy
  1. using System;  
  2. using Enyim.Caching;  
  3.   
  4.   
  5. namespace MemcacheTest  
  6. {  
  7.     /// <summary>  
  8.     /// MemcachedClient 帮组类 对外提供接口方法  
  9.     /// </summary>  
  10.     public class MemcachedHelper  
  11.     {  
  12.         /// <summary>  
  13.         /// 定义一个静态MemcachedClient客户端,它随类一起加载,所有对象共用  
  14.         /// </summary>  
  15.         private static MemcachedClient mclient;  
  16.         /// <summary>  
  17.         /// 静态构造函数,初始化Memcached客户端  
  18.         /// </summary>  
  19.         static MemcachedHelper()  
  20.         {  
  21.             mclient = MemCached.getInstance();  
  22.         }  
  23.         /// <summary>  
  24.         /// 向Memcached缓存中添加一条数据  
  25.         /// </summary>  
  26.         /// <param name="groupName">组名,用来区分不同的服务或应用场景</param>  
  27.         /// <param name="key">键</param>  
  28.         /// <param name="value">值</param>  
  29.         /// <param name="expiry">过期时间</param>  
  30.         /// <returns>返回是否添加成功</returns>  
  31.         public static bool SetValue(string groupName,string key, object value, DateTime expiry)  
  32.         {  
  33.             key = groupName + "-" + key;  
  34.             return mclient.Store(Enyim.Caching.Memcached.StoreMode.Set,key, value, expiry);  
  35.         }  
  36.         /// <summary>  
  37.         /// 向Memcached缓存中添加一条数据 默认超时24小时  
  38.         /// </summary>  
  39.         /// <param name="groupName">组名,用来区分不同的服务或应用场景</param>  
  40.         /// <param name="key"></param>  
  41.         /// <param name="value"></param>  
  42.         /// <returns></returns>  
  43.         public static bool SetValue(string groupName, string key, object value)  
  44.         {  
  45.             key = groupName + "-" + key;  
  46.             return mclient.Store(Enyim.Caching.Memcached.StoreMode.Set, key, value, DateTime.Now.AddHours(24));  
  47.         }  
  48.         /// <summary>  
  49.         /// 通过key 来得到一个对象  
  50.         /// </summary>  
  51.         /// <param name="groupName">组名,用来区分不同的服务或应用场景</param>  
  52.         /// <param name="key">键</param>  
  53.         /// <returns>对象</returns>  
  54.         public static object GetValue(string groupName, string key)  
  55.         {  
  56.             key = groupName + "-" + key;  
  57.             return mclient.Get(key);  
  58.         }  
  59.         /// <summary>  
  60.         /// 通过key 来得到一个对象(前类型)  
  61.         /// </summary>  
  62.         /// <typeparam name="T">类型</typeparam>  
  63.         /// <param name="groupName">组名,用来区分不同的服务或应用场景</param>  
  64.         /// <param name="key">键</param>  
  65.         /// <returns></returns>  
  66.         public static T GetValue<T>(string groupName, string key)  
  67.         {  
  68.             key = groupName + "-" + key;  
  69.             return mclient.Get<T>(key);  
  70.         }  
  71.         /// <summary>  
  72.         /// 清除指定key的cache  
  73.         /// </summary>  
  74.         /// <param name="groupName">组名,用来区分不同的服务或应用场景</param>  
  75.         /// <param name="key">键</param>  
  76.         /// <returns></returns>  
  77.         public static bool Remove(string groupName, string key)  
  78.         {  
  79.             key = groupName + "-" + key;  
  80.             return mclient.Remove(key);  
  81.         }  
  82.         /// <summary>  
  83.         /// 清除所有cache  
  84.         /// </summary>  
  85.         public static void RemoveAll()  
  86.         {  
  87.              mclient.FlushAll();  
  88.         }  
  89.     }  
  90. }  
[csharp]  view plain  copy
  1. using System.Net;  
  2. using Enyim.Caching;  
  3. using Enyim.Caching.Configuration;  
  4. using Enyim.Caching.Memcached;  
  5.   
  6.   
  7. namespace MemcacheTest  
  8. {  
  9.     /// <summary>  
  10.     /// MemcachedClient 配置类  
  11.     /// </summary>  
  12.     public sealed class MemCached  
  13.     {  
  14.         private static MemcachedClient MemClient;  
  15.         static readonly object padlock = new object();  
  16.         //线程安全的单例模式  
  17.         public static MemcachedClient getInstance()  
  18.         {  
  19.             if (MemClient == null)  
  20.             {  
  21.                 lock (padlock)  
  22.                 {  
  23.                     if (MemClient == null)  
  24.                     {  
  25.                         MemClientInit();  
  26.                     }  
  27.                 }  
  28.             }  
  29.             return MemClient;  
  30.         }  
  31.         static void MemClientInit()  
  32.         {  
  33.             //初始化缓存  
  34.             MemcachedClientConfiguration memConfig = new MemcachedClientConfiguration();  
  35.             IPAddress newaddress = IPAddress.Parse(Dns.GetHostEntry("XXXXXXXXXX.m.cnhzalicm10pub001.ocs.aliyuncs.com").AddressList[0].ToString()); //xxxx替换为ocs控制台上的“内网地址”  
  36.             IPEndPoint ipEndPoint = new IPEndPoint(newaddress, 11211);  
  37.             // 配置文件 - ip  
  38.             memConfig.Servers.Add(ipEndPoint);  
  39.             // 配置文件 - 协议  
  40.             memConfig.Protocol = MemcachedProtocol.Binary;  
  41.             // 配置文件-权限,如果使用了免密码功能,则无需设置userName和password  
  42.             memConfig.Authentication.Type = typeof(PlainTextAuthenticator);  
  43.             memConfig.Authentication.Parameters["zone"] = "";  
  44.             memConfig.Authentication.Parameters["userName"] = "XXXXXXXXXXXXXXXXX";  
  45.             memConfig.Authentication.Parameters["password"] = "XXXXXXXXXX";  
  46.             //下面请根据实例的最大连接数进行设置  
  47.             memConfig.SocketPool.MinPoolSize = 5;  
  48.             memConfig.SocketPool.MaxPoolSize = 200;  
  49.             MemClient = new MemcachedClient(memConfig);  
  50.         }  
  51.     }  
  52. }  
[csharp]  view plain  copy
  1. 程序调用  
  2.  MemcachedHelper.SetValue(groupName,strKey, strValue, DateTime.Now.AddMinutes(5));  
  3.   
  4. var restr = MemcachedHelper.GetValue(groupName,strKey);  
  5.   
  6. var obj = MemcachedHelper.GetValue<Product>(groupName,"p001");  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值