设为首页 收藏本站
查看: 932|回复: 0

[经验分享] memCached应用

[复制链接]

尚未签到

发表于 2015-9-1 09:54:39 | 显示全部楼层 |阅读模式
  Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached作为缓存技术的解决方案,已经是众所周知了;现在很多WEB应用都在使用它——包括一些知名的网站。若你还不知道这些,请在阅读之前先了解一下。   
        在ASP.NET中使用Memcached,有很多文章都有介绍,以下是我个人的使用经验。   
        一,准备   
        你需要有一下软件:   
       VS.NET(05/08)   
       SQLSERVER   
       memcached服务器端以及客户端类库(开源软件,下载即可)   
其中,客户端类库包括以下几个DLL:   
       Memcached.ClientLibrary.dll   
       ICSharpCode.SharpZipLib.dll   
       log4net.dll   
       二,安装memcached服务器端   
       将memcached.exe复制到任意目录下,如 c:,在命令行输入:   
memcached.exe -d install   
memcached将作为一个服务常驻系统内存了   
      三,建立ASP.NET工程   
     创建一个ASP.NETWEB项目,命名为MMCWEB,添加以上提到的几个客户端类库的引用。   
     四,配置   
     memcached使用了log4net,所以我们先配置log4net   
在web.config里找到configSections节点,添加以下内容   
<section name=&quot;log4net&quot; type=&quot;log4net.Config.Log4NetConfigurationSectionHandler, log4net&quot; />
  再在configSections节点之外,增加以下内容:   
<log4net>   
        <appender name=&quot;RollingLogFileAppender&quot; type=&quot;log4net.Appender.RollingFileAppender&quot;>   
            <param name=&quot;File&quot; value=&quot;LogFiles/&quot;/>   
            <param name=&quot;AppendToFile&quot; value=&quot;true&quot;/>   
            <param name=&quot;MaxSizeRollBackups&quot; value=&quot;10&quot;/>   
            <param name=&quot;StaticLogFileName&quot; value=&quot;false&quot;/>   
            <param name=&quot;DatePattern&quot; value=&quot;yyyy-MM-dd&quot;.txt&quot;&quot;/>   
            <param name=&quot;RollingStyle&quot; value=&quot;Date&quot;/>   
            <layout type=&quot;log4net.Layout.PatternLayout&quot;>   
                <param name=&quot;ConversionPattern&quot; value=&quot;%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger %ndc - %message%newline&quot;/>   
            </layout>   
        </appender>   
        <appender name=&quot;ConsoleAppender&quot; type=&quot;log4net.Appender.ConsoleAppender&quot;>   
            <layout type=&quot;log4net.Layout.PatternLayout&quot;>   
                <param name=&quot;ConversionPattern&quot; value=&quot;%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger %ndc - %message%newline&quot; />   
            </layout>   
        </appender>   
        <root>   
            <level value=&quot;ALL&quot; />   
            <appender-ref ref=&quot;RollingLogFileAppender&quot; />   
            <appender-ref ref=&quot;ConsoleAppender&quot; />   
        </root>   
        <logger name=&quot;Memcached.ClientLibrary&quot;>   
            <level value=&quot;WARN&quot; />
  </logger>   
    </log4net>   
启动调试,若没出现配置的出错提示,并且在网站目录下有文件夹LogFiles,就说明log4net配置成功了。
  五,初始化SockIOPool   
SockIOPool是什么东东?SockIOPool是Memcached客户端提供的一个套接字连接池,通俗讲,就是与Memcached服务器端交换数据的对象。SockIOPool在应用程序启动时初始化一次就可以了,我把这个工作放在 GLOBAL.ASAX.CS的Application_Start方法里   
char[] separator = { ',' };   
            string[] serverlist = ConfigurationManager.AppSettings[&quot;Memcached.ServerList&quot;].Split(separator);
  // initialize the pool for memcache servers   
            try   
            {   
                SockIOPool pool = SockIOPool.GetInstance();   
                pool.SetServers(serverlist);
  pool.InitConnections = 3;   
                pool.MinConnections = 3;   
                pool.MaxConnections = 50;
  pool.SocketConnectTimeout = 1000;   
                pool.SocketTimeout = 3000;
  pool.MaintenanceSleep = 30;   
                pool.Failover = true;
  pool.Nagle = false;   
                pool.Initialize();   
            }   
            catch (Exception err)   
            {   
                //这里就可以用Log4Net记录Error啦!   
            }
  注意AppSettings[&quot;Memcached.ServerList&quot;]是在WEB.CONFIG里设置的,所以WEB.CONFIG的appSettings的子节点里需要有以下一行   
<add key=&quot;Memcached.ServerList&quot; value=&quot;127.0.0.1:11211&quot;/>   
启动调试服务器,若没有出错的日志记录,说明IO连接池已经开辟成功。   
        六,使用Memcached   
       终于进入正题了,不过使用之前,我们还需要准备一些数据。   
      创建一个实体类People,并加上Serializable属性!!!   
      对应的数据库里,增加一张表,字段对应实体类,插入一些测试数据。持久层和业务层的设计就略过了,他们负责向提供一些数据,返回类型可自定,若ILIST,DATASET。   
     Memcached使用起来就很简单了,比如后台检索出一组People类型的数据,放在一个叫peopleList的arraylist里,而且这个arraylist要频繁使用,只需要这样   
MemcachedClient mc = new MemcachedClient();   
mc.EnableCompression = true;   
mc.Set(key, peopleList);     
         上面的key是用来访问这个arraylist的键,Memcached里的数据都是保存为键-值对的。   
一旦mc.KeyExists(key)为TRUE,就用return mc.Get(key) as ArrayList提取数据,删除时,使用 return mc.Delete(key);等等。可以自己琢磨了。
  以上只是演示,其实数据缓存是一项复杂而繁琐的工作,不仅需要后台代码的分层优化,也需要数据库对大数据量访问的策略和调优。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-108235-1-1.html 上篇帖子: BeIT Memcached 下篇帖子: 应对Memcached缓存失效,导致高并发查询DB的几种思路
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表