.NET中使用Memcached的相关资源整理

 

Memcached官方站点:http://www.danga.com/memcached/

Memcached Win32 1.2.6下载:http://code.jellycan.com/memcached/

安装帮助:Windows下的.NET+ Memcached安装

Memcached .NET客户端:

1).NET memcached client library

  下载地址:https://sourceforge.net/projects/memcacheddotnet

  相关文章:分布式缓存系统Memcached简介与实践

2)enyim.com Memcached Client

  下载地址:http://www.codeplex.com/EnyimMemcached/

  相关文章:memcached系列2:memcached实例  

3)Memcached Providers

  下载地址:http://www.codeplex.com/memcachedproviders

  相关文章:.NET平台上的Memcached客户端介绍

4) BeIT Memcached

  下载地址:http://code.google.com/p/beitmemcached/

  相关文章:分布式缓存BeIT Memcached简介

相关链接:

a) Memcached for Windows
b) Which .NET Memcached client do you use, EnyimMemcached vs. BeITMemcached?
c) 博客园知识库Memcached相关文章

 
http://www.cnblogs.com/dudu/archive/2009/07/19/1526407.html

 
 
 

Memcached客户端.用的是memcacheddotnet_clientlib-1.1.5,其他的几款客户端原理都一样.

研究了一下源码,感觉memcacheddotnet表现还是很不错的.

MemCached还不支持缓存依赖..希望后续版本会增加这个功能.

[STAThread]
static void Main(string[] args)
{
//服务器端列表
string[] serverlist = { "127.0.0.1:11211" };
//初始化池
SockIOPool sock = SockIOPool.GetInstance();
sock.SetServers(serverlist);//添加服务器列表
sock.InitConnections = 3;//设置连接池初始数目
sock.MinConnections = 3;//设置最小连接数目
sock.MaxConnections = 5;//设置最大连接数目
sock.SocketConnectTimeout = 1000;//设置连接的套接字超时。
sock.SocketTimeout = 3000;//设置套接字超时读取
sock.MaintenanceSleep = 30;//设置维护线程运行的睡眠时间。如果设置为0,那么维护线程将不会启动;
//获取或设置池的故障标志。
//如果这个标志被设置为true则socket连接失败,
//将试图从另一台服务器返回一个套接字如果存在的话。
//如果设置为false,则得到一个套接字如果存在的话。否则返回NULL,如果它无法连接到请求的服务器。
sock.Failover = true;
//如果为false,对所有创建的套接字关闭Nagle的算法。
sock.Nagle = false;
sock.Initialize(); //获取客户端实例
MemcachedClient memcached = new MemcachedClient();
//是否启用压缩数据
memcached.EnableCompression = false;
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached Set");
//存储缓存数据。
//如果数据在服务器上不存在此键,或者如果键被删除指定的值将不被保存。
//到期时间到达时服务器会自动删除该键值.
//如果启用了压缩,数据压缩长于门槛的数据将被储存在压缩的形式。
//在当前版本中,所有对象会使用。NET序列化。
//参数说明:
//key:缓存的键.value:缓存对象. expiry:过期时间.hashCode:如果不为null,则诠释哈希码使用
//asString :作为字符串存储该对象
memcached.Set("test1", "test1");
Console.WriteLine(memcached.Get("test1"));
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached Add ,先Add再调用Set 相同键值Set会覆盖掉Add的值");
memcached.Add("test2", "value2");
Console.WriteLine(memcached.Get("test2"));
memcached.Set("test2", "value1 value2");
Console.WriteLine(memcached.Get("test2"));
Console.WriteLine("Memcached Replace ");
//在服务器上更新数据,指定键和值。
memcached.Replace("test2", "value3");
Console.WriteLine(memcached.Get("test2")); Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached 键值是否存在");
if (memcached.KeyExists("test2"))
{
Console.WriteLine("键test2 存在");
}
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~~~~Memcached 删除数据");
memcached.Add("test4", "value4");
Console.WriteLine("test4==>" + memcached.Get("test4"));
memcached.Delete("test4");
if (!memcached.KeyExists("test4"))
{
Console.WriteLine("test4 已将删除");
}
Console.WriteLine("~~~~~~~~~~~~~~~~~~~~~~~Memcached 数据过期");
memcached.Add("test5", "value5", DateTime.Now.AddMilliseconds(5000));
Console.WriteLine(memcached.Get("test5"));
System.Threading.Thread.Sleep(6000);
Console.WriteLine("过期: " + memcached.Get("test5"));
Console.Read();
SockIOPool.GetInstance().Shutdown(); //关闭池, 关闭sockets
}

属性

SockIOPool pool = SockIOPool.GetInstance();
//pool.CheckIn;
//pool.Equals;
//pool.Failover; // 设置SockIO池的故障标志
//pool.GetConnection;
//pool.GetHashCode;
//pool.GetSock;
//pool.GetType;
//pool.HashingAlgorithm;
//pool.InitConnections;// 设置连接池初始数目
//pool.MinConnections;// 设置连接池最小连接数目
//pool.MaxConnections; // 设置连接池最大连接数目
//pool.Initialize; // 正式初始化容器
//pool.Initialized;
//pool.MaintenanceSleep; // 设置维护线程运行的睡眠时间:如果设置为0,那么维护线程将不会启动
//pool.MaxBusy;
//pool.MaxIdle;
//pool.Nagle; // 是否用nagle算法启动
//pool.Servers;
//pool.SetServers;// // 添加服务器列表(数组)
//pool.SetWeights;
//pool.Shutdown;
//pool.SocketConnectTimeout;// 设置连接的套接字超时时间(单位:毫秒)
//pool.SocketTimeout; // 设置套接字超时时间(单位:毫秒)
//pool.Weights;

memcached一些整理的更多相关文章

  1. Memcached函数整理

    public bool Memcached::add ( string $key , mixed $value [, int $expiration ] )  向key中添加值,如果key存在,返回f ...

  2. 分布式内存对象缓存系统Memcached-概述

    全面掌握Memcached 1.       概述 Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,是为了加快网站http://www. ...

  3. NET Core2.0 Memcached踩坑,基于EnyimMemcachedCore整理MemcachedHelper帮助类。

    DotNetCore2.0下使用memcached缓存. Memcached目前微软暂未支持,暂只支持Redis,由于项目历史原因,先用博客园开源项目EnyimMemcachedCore,后续用到的时 ...

  4. Asp.Net Core 2.0 项目实战(5)Memcached踩坑,基于EnyimMemcachedCore整理MemcachedHelper帮助类。

    Asp.Net Core 2.0 项目实战(1) NCMVC开源下载了 Asp.Net Core 2.0 项目实战(2)NCMVC一个基于Net Core2.0搭建的角色权限管理开发框架 Asp.Ne ...

  5. .NET中使用Memcached的相关资源整理

    Memcached官方站点:http://www.danga.com/memcached/ Memcached Win32 1.2.6下载:http://code.jellycan.com/memca ...

  6. php-- memcache 与 memcached支架的区别与共同点 个人整理

    首先声明:memcache 与 memcached 之间没有关系 1.概念相似 MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载. m ...

  7. .NET中使用Memcached的相关资源整理(转)

    Memcached官方站点:http://www.danga.com/memcached/ Memcached Win32 1.2.6下载:http://code.jellycan.com/memca ...

  8. 4.windows环境下如何安装memcached教程(转载+自己整理)

     Memcached 是一个开源免费高性能的分布式内存对象缓存系统,能够加快网站访问速度和减轻数据库压力,本文向大家介绍下windows环境下如何安装memcached.百度经验:jingyan. ...

  9. memcached内存管理机制[未整理]

    memcached默认采用的是Slab Allocator的机制分配管理内存的,在此之前,内存的分配是通过对所有的记录简单地进行malloc和free来进行的,但这种方式容易造成很多内存碎片,加重操作 ...

随机推荐

  1. C# 网络编程之豆瓣OAuth2.0认证具体解释和遇到的各种问题及解决

            近期在帮人弄一个豆瓣API应用,在豆瓣的OAuth2.0认证过程中遇到了各种问题,同一时候自己须要一个个的尝试与解决,终于完毕了豆瓣API的訪问.作者这里就不再吐槽豆瓣的认证文档了,毕 ...

  2. Lazy Load 图片延迟加载(转)

    jQuery Lazy Load 图片延迟加载来源 基于 jQuery 的图片延迟加载插件,在用户滚动页面到图片之后才进行加载. 对于有较多的图片的网页,使用图片延迟加载,能有效的提高页面加载速度. ...

  3. MSSQL计算日期方法大全

    通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天.你们大部分人大概都知道怎样把日期进行分割(年.月.日等),然后仅仅用分割出来的年.月.日等放在几个函 ...

  4. dd,实现系统备份

    一.dd的使用 dd命令的解释dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾则乘以相应的数字:b=512:c=1:k=1024:w=2 参数: ...

  5. linux 查看文件命令总结

    linux 查看文件命令总结 1.cat 查看文件内容 选项-b 空白行不显示行号.-n,空白行显示 2.more 查看文件内容,通过空格键查看下一页 q键退出查看 3.less 和上同,多了方向键( ...

  6. Visual Studio 2012 Web一键式发布

    按照保哥的介绍,尝试“ Web一键式发布”,但总是出错,主要就是404错误,不知道是什么原因.默认的 Web一键式发布是在C:\inetpub\wwwroot目录下,难道是权限问题?折腾N久无果.好吧 ...

  7. Android反射机制实现与原理

    本文介绍Android反射机制实现与原理,在介绍之前,要和Java进行比较,所以先看下Java中的反射相关知识: 一.反射的概念及在Java中的类反射 反射主要是指程序可以访问.检测和修改它本身状态或 ...

  8. MAC 环境下初始化mysql root 密码

    1. 关掉mysql服务,打开系统设置最后的mysql,然后将mysql先关掉 2. 生成一个文件命名mysql-init,文件中放入:一句话,这句话不同版本不一样,如下:(括号里面不包含) alte ...

  9. C#如何加载程序运行目录外的程序集

    我们的应用程序部署的时候,目录结构一般不会只有运行程序的目录这一个,我们可能在运行目录下建子目录,也可能使用System32目录,也可能使用其它第三方的程序集..Net程序集 首先会在GAC中搜索相应 ...

  10. 关于Eclipse中的快捷键占用的解决.

    刚进公司用的之前离职员工的电脑,打开Eclipse经常用的一个alt+/ 内容提示快捷键就是不好使. 让同事帮忙之后才发现原因. 在eclipse中快捷键设置是在  windows---->pr ...