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