池的概念

SockIOPool

首先来看下属性

    1. SockIOPool属性 
      boolean initialized = false – 初始化是否完成的标志,只有初始化完成后上层才能正常使用池 
      int initConn = 10 – 初始化时对每个服务器建立的连接数目 
      int minConn = 5 – 每个服务器建立最小的连接数,当自查线程发现与某个服务器建立连接数目小于这个数目时 
      会弥补剩下的连接 
      int maxConn = 100 -每个服务器建立最大的连接数,当自查线程发现与某个服务器建立连接数目大于这个数目 
      时就会逐个检查这些连接的空闲时间是否大于maxConn,如果大于会关闭这些连接,直到连接数等于maxConn 
      long maxIdle = 1000 * 60 * 5 – 最大空闲时间 
      long maxBusyTime = 1000 * 30 – 最长租用时间,其使用主要有两点,一是自查线程会检查正在被租用的连接, 
      如果发现已经被租用的时间超过这个值得,会将其从被租用的记录里剔除,并关闭这个连接;另一个应用是 
      上层进行MUTIL操作时,读取所有的数据的时间不能超过这个时间。 
      long maintSleep = 1000 * 30 – 自查线程周期进行工作,其每次休眠时间 
      int socketTO = 1000 * 3 – Socket阻塞读取数据的超时时间 
      int socketConnectTO = 1000 * 3 - Socket阻塞建立连接的等待时间 
      boolean aliveCheck = false -根据key&hashCode获取SockIO时,通过hash bucket得到SockIO后,如果这个值 
      是true会检查Socket是否已经连接,如果连接建立正常还会想服务器发送“version\r\n”的指令,并读取数据,这 
      个过程没有出错才会返回SockIO给上层用,否则返回NULL。所以一般设置为false。 
      boolean nagle = false – Socket的参数,如果是true在写数据时不缓冲,立即发送出去 
      int hashingAlg = NATIVE_HASH – 池的hash bucket方式,主要是分为简单的hashCode取hash bucket数目的模 
      和一致性哈希,前者在扩容时会造成命中率很大程度的下降,后者的好处是扩容时很大程度减少了缓存的重新 
      分布 
      String[] servers – memcached服务器地址配置 
      Integer[] weights – memcached服务器权重配置 
      List buckets - hash bucket,一个服务器地址,其权重是N,则往这个bucket中添加N个服务器地址 
      TreeMap
    2. 其次就是在自己的本地安装一个 memcached
    3. 建立  MemcacheHelper.cs类

      public class MemcacheHelper
      {
      private readonly static MemcachedClient mc = null;
      static MemcacheHelper()
      {
      string[] serverlist = { "填写装了服务IP地址1", "10.0.0.132:11211" };//有几个写几个

      //初始化池
      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();

      // 获得客户端实例
      mc = new MemcachedClient();
      mc.EnableCompression = false;
      }
      /// <summary>
      /// 向Memcache中添加数据
      /// </summary>
      /// <param name="key"></param>
      /// <param name="value"></param>
      public static bool Set(string key, object value)
      {
      return mc.Set(key, value);
      }
      public static bool Set(string key, object value,DateTime time)
      {
      return mc.Set(key, value,time);
      }
      /// <summary>
      /// 获取数据
      /// </summary>
      /// <param name="key"></param>
      /// <returns></returns>
      public static object Get(string key)
      {
      return mc.Get(key);
      }
      /// <summary>
      /// 删除
      /// </summary>
      /// <param name="key"></param>
      public static bool Delete(string key)
      {
      if (mc.KeyExists(key))
      {
      return mc.Delete(key);
      }
      return false;
      }
      }

    4. 现在就可以调用这个方法了。主要就是一个池的概念。 
      1. string sessionId = Guid.NewGuid().ToString();//必须保证Memcache的key唯一
        Common.MemcacheHelper.Set(sessionId,数据, DateTime.Now.AddMinutes(20));//向Memcache中添加登录用户数据.
        Response.Cookies["sessionId"].Value = sessionId;//将自创的SessionId以Cookie的形式返回给浏览器。

memcached 的 SockIOPool 概念的更多相关文章

  1. 一,memcached的基本概念

    1,memcached的基本概念 memcached是一个高效的分布式内存对象缓存系统,它可以支持把各种php的数据(array,对象,基本数据类型)放入到它管理的内存中.简单的说,memcached ...

  2. Memcached Memcached.ClientLibrary.SockIOPool”的类型初始值设定项引发异常

    又一次遭遇"xxx类型初始值设定项引发异常" 下了个c#实现的轻量级IoC开源项目,可是在本地使用时发现一运行就捕捉到"类型初始值设定项引发异常"的异常信息,调 ...

  3. memcached缓存基本概念

    Memcached是一套分布式内存对象缓存系统. 用于在动态应用系统中缓存数据库的数据,减少数据库的访问压力,达到提升网站系统性能的目的:memcached在企业应用场景中一般是用来作为数据库的cac ...

  4. Python自动化 【第十一篇】:Python进阶-RabbitMQ队列/Memcached/Redis

     本节内容: RabbitMQ队列 Memcached Redis 1.  RabbitMQ 安装 http://www.rabbitmq.com/install-standalone-mac.htm ...

  5. Memcached报错

    1. ERROR Memcached.ClientLibrary.SockIOPool [(.6271ms 解决办法:据说是因为定期清理应用池的原因.

  6. java + memcached安装

    一:安装 (临时获取上手windows实验) 1.下载memcached.exe , 上F:\memcached\ 下 2.在CMD在输入 "F:\memcached\memcached.e ...

  7. Java操作Memcached

    本文复制其他播客,有好的技术文章希望各位大神能告知... 谢谢. 如何使用Java操作Memcached实例: 代码一: package com.ghj.packageoftool; import j ...

  8. memcached—Java操作Memcached实例

    前面博客介绍了如何在Windows操作系统中安装Memcached,总结一下如何使用Java操作Memcached实例: 代码一: package com.ghj.packageoftool; imp ...

  9. 华丽的NHibernate

    华丽的NHibernate http://www.cnblogs.com/kissdodog/archive/2013/02/21/2919886.html 华丽的NHibernate NHibern ...

随机推荐

  1. J07-Java IO流总结七 《 InputStreamReader和OutputStreamWriter 》

    前面在介绍FileReader和FileWriter的时候有说到,FileReader的读取字符功能,以及FileWriter的写出字符的功能,都不是它们自己实现的,而是,它们分别继承了InputSt ...

  2. dubbo学习(1)--简单的入门搭建实例

    转载请注明源文出处:http://www.cnblogs.com/lighten/p/6828026.html 1 简介 dubbo是一个分布式服务框架,由阿里巴巴的工程师开发,致力于提供高性能和透明 ...

  3. 【C#小知识】C#中一些易混淆概念总结(六)---------解析里氏替换原则,虚方法 分类: C# 2014-02-08 01:53 1826人阅读 评论(0) 收藏

    目录: [C#小知识]C#中一些易混淆概念总结--------数据类型存储位置,方法调用,out和ref参数的使用 [C#小知识]C#中一些易混淆概念总结(二)--------构造函数,this关键字 ...

  4. 全网最详细的跑python2.7时出现from mysql import connector ImportError: No module named mysql的问题解决办法(图文详解)

    不多说,直接上干货! C:\Users\lenovo>pip install mysql-connector-python-rf== Collecting mysql-connector-pyt ...

  5. Fiddler Web Debugger是什么?(图文详解)

    不多说,直接上干货! 1.为什么是Fiddler? 抓包工具有很多,小到最常用的web调试工具firebug,达到通用的强大的抓包工具wireshark. 见 Windows里安装wireshark或 ...

  6. 在Bash中定制炫酷的命令提示符

    如果你使用的是Linux桌面(例如:Fedora或者Ubuntu)的话,在Terminal上使用Bash通常是必须地,但是默认的Bash提示符都很普通.本文将提供简单的Bash脚本(通过定制PS1)定 ...

  7. vue权限路由实现方式总结二

    之前已经写过一篇关于vue权限路由实现方式总结的文章,经过一段时间的踩坑和总结,下面说说目前我认为比较"完美"的一种方案:菜单与路由完全由后端提供. 菜单与路由完全由后端返回 这种 ...

  8. (在数据库中调用webservices。)SQL Server 阻止了对组件 'Ole Automation Procedures' 的 过程'sys.sp_OACreate' 的访问

    --开启 Ole Automation Procedures sp_configure 'show advanced options', 1; GO RECONFIGURE; GO sp_config ...

  9. Json.Net 反序列化成匿名对象

    反序列化一个object var str1 = "{id:1,name:'111',x:[1,2,3],y:{a:'ssss',b:'dddd'}"; var obj1 = Jso ...

  10. Error: EACCES: permission denied, access '/usr/local/lib/node_modules'

    sudo chown -R username /usr/local/lib/node_modules 注:username要具有/usr/local/lib/node_modules的读写权限