设为首页 收藏本站
查看: 1200|回复: 0

[经验分享] memcached使用说明

[复制链接]

尚未签到

发表于 2015-9-1 08:14:09 | 显示全部楼层 |阅读模式
  1、在服务器上注册服务
DSC0000.png
  
  2、启动服务:services.msc
  
DSC0001.png
  
  
  3、客户端创建服务接口
   




object Get(string key);

List<string> GetKeys();

List<object> GetValues();

void Set(string key, object value);

void Set(string key, object value, DateTime expiration);

void Set(string key, object value, TimeSpan expiration);

bool Exists(string key);

void Remove(string key);

void RemoveAll();
}
  
  
  4、客户端创建接口实现
  引入Memcached.ClientLibrary,版本为1.0.0.0,还需要引入了log4net,版本为1.2.10.0,其它版本会报异常。



public class MemcachedCache : ICache
{
private static readonly SockIOPool pool = SockIOPool.GetInstance("Project");
private static MemcachedClient client;
private static ILog log = LogManager.GetLogger("memcached-log");

static MemcachedCache()
{
var config = ConfigurationManager.AppSettings["memcached-server"];
if (string.IsNullOrWhiteSpace(config))
{
log.Info("没有配置Memcached服务器IP!");
return;
}

try
{
string[] serverList = config.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries);
pool.SetServers(serverList);
pool.Initialize();

client = new MemcachedClient();
client.PoolName = "Project";
client.EnableCompression = false;
}
catch (Exception e)
{
log.Info(string.Format("Memcached初始化异常:{0}", e.Message));
return;
}

log.Info("Memchached客户端初始化完成!");
}


public object Get(string key)
{
return client.Get(key);
}

public List<string> GetKeys()
{
var keys = new List<string>();
//IDictionaryEnumerator de = client.ke();
//while (de.MoveNext())
//{
//    keys.Add(de.Key.ToString());
//}

return keys;
}

public List<object> GetValues()
{
var values = new List<object>();
//IDictionaryEnumerator de = client.GetEnumerator();
//while (de.MoveNext())
//{
//    values.Add(de.Value);
//}

return values;
}

public void Set(string key, object value)
{
client.Set(key, value);
}

public void Set(string key, object value, DateTime expiration)
{
client.Set(key, value, expiration);
}

public void Set(string key, object value, TimeSpan expiration)
{
client.Set(key, value, DateTime.Now.Add(expiration));
}

public bool Exists(string key)
{
return client.KeyExists(key);
}

public void Remove(string key)
{
if (Exists(key))
{
client.Delete(key);
}
}

public void RemoveAll()
{
foreach (var item in GetKeys())
{
Remove(item);
}
}
}
  
  
  5、客户端配置
  

<configSections>


    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>


<appSettings>
<!--服务器IP端口列表,这里的端口号是memcached默认监控的端口号-->
<add key="memcached-server" value="192.0.0.1:11211;192.0.0.2:11211;"/>
</appSettings>

<log4net>
<root>
<level value="ALL" />
<appender-ref ref="RollingLogFileAppender" />
</root>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="./log/aaa-" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="10" />
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyyMMdd&quot;.log&quot;" />
<param name="RollingStyle" value="Date" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="[%d] [%-5t] [%-5p] -- %m%n" />
</layout>
</appender>
</log4net>
  
  6、客户端写入获取缓存代码
    //Autofac获取实现



   IContainer container = ContainerInit.GetContainer();

var cache = container.Resolve<ICache>();
cache.Set("MyName", "James");
cache.Set("MyAge", 30);

var value = cache.Get("MyAge");
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-108108-1-1.html 上篇帖子: [教程]centos下安装memcached并设置开机自动启动-两种方法 下篇帖子: 转:分布式缓存系统Memcached简介与实践
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表