.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
2)enyim.com Memcached Client
下载地址:http://www.codeplex.com/EnyimMemcached/
3)Memcached Providers
下载地址:http://www.codeplex.com/memcachedproviders
4) BeIT Memcached
下载地址:http://code.google.com/p/beitmemcached/
相关链接:
a) Memcached for Windowsb) Which .NET Memcached client do you use, EnyimMemcached vs. BeITMemcached?
c) 博客园知识库Memcached相关文章
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;