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

[经验分享] 集群架构实践

[复制链接]

尚未签到

发表于 2015-9-1 12:58:03 | 显示全部楼层 |阅读模式
  由于最近忙工作实习的事情,又要忙学校的毕业设计,所以很久没在博客上分享自己的技术实践成果了,真的很抱歉。今天我在整理自己毕业设计的时候,我觉得有一样东西不得不推荐给大家,这个东西就叫Memcached。可能有些朋友已经对他非常熟悉,也可能已经用得非常溜,但我想对于像我一样的初学者来说,这篇文章应该还是能帮助一些初学者朋友解决一些有关使用Memcached的问题的。
  首先,我先简单介绍一下Memcached是什么样的东西。其实说白了他就是一个缓存框架,但与普通缓存不同的是他能支持分布式集群部署,想象一下,当你需要缓存的数据很多时,你可能需要加入更多的服务器来满足你的数据缓存需求。下面是更专业的解释(其实太多的术语反而会让大家觉得这个东西很复杂)。
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。
  很简单,他就是用来作缓存的,一般应用在你的应用和数据库之间,缓解数据库服务器的I/O负载压力。因为他能满足分布式集群的特性,所以我对他非常感兴趣,于是自己就在.NET上简单实现了一个demo,顺便把实现的过程记录了下来,以便以后自己翻阅,当然也为那些初学者提供一个现成的思路。
  准备工作
  下载Windows版本的Memcached服务器,下载地址:http://www.itivy.com/DownloadFile.ashx?id=634418560909724471
  下载.NET中可用的Memcached客户端,这里我用了Enyim的客户端,下载地址:http://www.itivy.com/DownloadFile.ashx?id=634418565974010508
  配置工作
  第一步先启动memcached服务:
  将下载的压缩包解压到c:\
  你可以直接双击memcached.exe图标运行memcached,我们还可以采取cmd命令行模式下启动memcached。

  这时候细心的你应该注意到你的taskmanager中多了一个memcached进程,是的,这时候memcached服务已经启动了。
  第二步配置memcached客户端:
  这里我们为了在演示中看到缓存的效果,故新建了两个网站,每一个网站都可以设置和读取缓存内容,如在webA中设置了缓存,可以在webB中获取由webA设置的缓存内容。下面我们来配置一下这两个网站的web.config文件,在configuration节点下添加以下配置信息:



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24


<configsections>
    <!--Memcached客户端配置信息-->
    <sectiongroup name="enyim.com">
      <section name="memcached" type="Enyim.Caching.Configuration.MemcachedClientSection, Enyim.Caching">
    </section>
    <section name="memcached" type="Enyim.Caching.Configuration.MemcachedClientSection, Enyim.Caching">
  </section>
  <enyim.com>
    <memcached>
      <servers>
        <!-- put your own server(s) here-->
        <add address="192.168.1.150" port="11211">
      </add>
      <socketpool minpoolsize="10" maxpoolsize="100" connectiontimeout="00:00:00.5000000" deadtimeout="00:00:00.5000000">
    </socketpool>
  </servers>
  <!--Memcached客户端配置信息-->
  <appsettings>
    <!--系统统一缓存策略-->
    <add key="CacheStrategy" value="MyCache.Core.MemcachedCacheStrategy,MyCache.Core">
    <!--系统统一缓存策略的缓存时间-->
    <add key="CacheTimeOut" value="60">
  </add>
<connectionstrings></connectionstrings></add></appsettings></memcached></enyim.com></sectiongroup></configsections>
  这里可能你不太明白的是为什么在appSettings中加一个CacheStrategy,其实这个是为了抽象缓存接口,我们可以采用Memcached缓存方案,也可以采用.NET自带的缓存方案,也可以是其他的缓存方案,所以还是让程序在运行时自动加载某种方案吧。这个我在最后会把源代码发上来,你一看就明白怎么回事了。另外,配置中的IP自己设置,这种常识就不多说了。
  测试工作
  OK,客户端也配置完成了,让我们来看看测试效果吧。在网站A,B中各设置两个按钮,一个用来设置缓存,一个用来获取缓存,按钮事件如下:
  网站A设置缓存按钮代码:



1
2
3
4


protected void Button1_Click(object sender, EventArgs e)
{
     MyCache.Core.WebCache.Add("Test", "我是Test,我的值是A 来自 WEBA");
}
  网站A获取缓存按钮代码:



1
2
3
4


protected void Button2_Click(object sender, EventArgs e)
{
     Response.Write(MyCache.Core.WebCache.Retrieve("Test"));
}
  网站B设置缓存按钮代码:



1
2
3
4


protected void Button1_Click(object sender, EventArgs e)
{
     MyCache.Core.WebCache.Add("Test", "我是Test,我的值是B 来自 WEBB");
}
  网站B获取缓存按钮代码:



1
2
3
4


protected void Button2_Click(object sender, EventArgs e)
{
     Response.Write(MyCache.Core.WebCache.Retrieve("Test"));
}
  好了,开始测试吧,我们先在网站A中设置一下缓存,然后在网站A中获取缓存和在网站B中获取缓存,页面都显示如下:

  这说明我们在网站A中设置的缓存已经可以被网站A和网站B同时获取,OK,测试成功了。
  当然,我们在网站B中设置缓存也是一样,这里就不再赘述了。
  最后附上测试源码,源码可以用vs2005及以上版本打开,点击下载源码。希望本文能帮到一部分朋友。

运维网声明 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-108371-1-1.html 上篇帖子: 第3章 memcached的删除机制和发展方向 下篇帖子: Memcached-----memcached实现内存缓存【转载】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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