集群架构实践 - 初试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及以上版本打开,点击下载源码。希望本文能帮到一部分朋友。

你可能感兴趣的:(memcached)