• C#操作Memcached


    memcached客户端库

    .Net memcached client
    https://sourceforge.net/projects/memcacheddotnet

    .Net 2.0 memcached client
    http://www.codeplex.com/EnyimMemcached

    Client developed in .NET 2.0 keeping performance and extensibility in mind. (Supports consistent hashing.)
    http://www.codeplex.com/memcachedproviders

    BeIT Memcached Client (optimized C# 2.0)
    http://code.google.com/p/beitmemcached

                int runs = 100;
                int start = 200;
                if(args.Length > 1)
                {
                    runs = int.Parse(args[0]);
                    start = int.Parse(args[1]);
                }
    
                string[] serverlist = { "192.168.0.191:11211" };//可以添加多个服务器
    
                //为服务器初始化IO连接池 initialize the pool for memcache servers
                SockIOPool pool = SockIOPool.GetInstance();
                pool.SetServers(serverlist);
                pool.InitConnections = 3;
                pool.MinConnections = 3;
                pool.MaxConnections = 5;
    
                pool.SocketConnectTimeout = 1000;
                pool.SocketTimeout = 3000;
    
                pool.MaintenanceSleep = 30;
                pool.Failover = true;
    
                pool.Nagle = false;
                pool.Initialize();
    //            SockIOPool pool = SockIOPool.Instance;
    //            pool.Servers = serverlist;
    //            pool.InitConn = 5;
    //            pool.MinConn = 5;
    //            pool.MaxConn = 50;
    //            pool.MaintSleep = 30;
    //            pool.SocketTO = 1000;
    //            pool.Nagle = false;
    //            pool.Initialize();

    //建立一个客户端实例 MemcachedClient mc = new MemcachedClient(); mc.EnableCompression = false; // MemcachedClient mc = new MemcachedClient(); // mc.CompressEnable = false; // mc.CompressThreshold = 0; // mc.Serialize = true; string keyBase = "testKey"; string obj = "这是缓存的内容,如果很大,注意序列化的开销。也可以压缩后传输。东莞市长安镇图书馆。"; long begin = DateTime.Now.Ticks; for(int i = start; i < start+runs; i++) {
    //写入缓存 mc.Set(keyBase
    + i, obj); } long end = DateTime.Now.Ticks; long time = end - begin; Console.WriteLine(runs + " sets: " + new TimeSpan(time).ToString() + "ms"); begin = DateTime.Now.Ticks; int hits = 0; int misses = 0; for(int i = start; i < start+runs; i++) {
    //读缓存
    string str = (string) mc.Get(keyBase + i); if(str != null) ++hits; else ++misses; } end = DateTime.Now.Ticks; time = end - begin; Console.WriteLine(runs + " gets: " + new TimeSpan(time).ToString() + "ms"); Console.WriteLine("Cache hits: " + hits.ToString()); Console.WriteLine("Cache misses: " + misses.ToString()); //枚举服务器的状态 IDictionary stats = mc.Stats(); foreach(string key1 in stats.Keys) { Console.WriteLine(key1); Hashtable values = (Hashtable)stats[key1]; foreach(string key2 in values.Keys) { Console.WriteLine(key2 + ":" + values[key2]); } Console.WriteLine(); } SockIOPool.GetInstance().Shutdown(); Console.ReadLine();
  • 相关阅读:
    ST表
    容斥原理
    扩展欧几里得算法
    C++ 快读快写模板
    单例模式的装饰器实现
    使用python+poco+夜神模拟器进行自动化测试
    使用Airtest超快速开发App爬虫
    mysql优化
    在浏览器中输入URL并回车后都发生了什么?
    第一次博客作业
  • 原文地址:https://www.cnblogs.com/shi5588/p/4202779.html
Copyright © 2020-2023  润新知