pre { /*控制代码不换行*/ white-space: pre; word-wrap: normal; }

集群架构实践 - 初试Memcached

由于最近忙工作实习的事情,又要忙学校的毕业设计,所以很久没在博客上分享自己的技术实践成果了,真的很抱歉。今天我在整理自己毕业设计的时候,我 觉得有一样东西不得不推荐给大家,这个东西就叫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及以上版本打开,点击下载源码。希望本文能帮到一部分朋友。

posted @ 2011-09-05 17:28  monkey's  阅读(409)  评论(0编辑  收藏  举报