zoukankan      html  css  js  c++  java
  • memcached一些整理

     
     

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

  • 相关阅读:
    javascript中的require、import和export模块文件
    MFC CDHtmlDialog 加载本地资源
    互斥和信号量
    CString与char *互转总结
    MFC消息-自定义消息
    Python网络爬虫之Scrapy框架(CrawlSpider)
    scrapy中selenium的应用
    UA池和代理池
    抓取js动态生成的数据分析案例
    scrapy框架的日志等级和请求传参
  • 原文地址:https://www.cnblogs.com/lijiasnong/p/4936232.html
Copyright © 2011-2022 走看看