memcached一些整理

来源:互联网 发布:售电软件哪家好 编辑:程序博客网 时间:2024/05/16 05:49

.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        }

0 0
原创粉丝点击