Memcached
是一个高性能的分布式内存
对象缓存系统,用于动态Web
应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached
基于一个存储键/值对的hashmap
。其守护进程(daemon )是用C写的,但是客户端
可以用任何语言来编写,并通过memcached协议与守护进程通信。但是它并不提供冗余(例如,复制其hashmap条目);当某个服务器S停止运行或崩溃了,所有存放在S上的键/值对都将丢失。
Memcached
由Danga
Interactive
开发,其最新版本发布于2010年,作者为Anatoly Vorobey
和Brad
Fitzpatrick。用于提升LiveJournal .
com访问速度的。LJ每秒动态页面访问量几千次,用户700万。Memcached
将数据库负载大幅度降低,更好的分配资源,更快速访问。\
源地址
:http://baike.baidu.com/view/794242.htm
阿蜜果
源地址: http://www.blogjava.net/amigoxie/archive/2011/02/15/344381.html
Memcached
的安装
2.1
主程序的安装
一般的服务器都是采用
Linux,笔者只是讲述在
Windows上如何安装
Memcached,在
Linux上的安装请参考网上其它资料。
Windows版本的下载地址为:
http://code.jellycan.com/memcached/
当前
win32的最新版本是
1.2.6,下载页面参考如下:
在上图中点击“
memcached-1.2.6-win32-bin.zip
”进入下载页面,下载后,将其解压到
D盘下,解压后的
D:"memcached-1.2.6-win32-bin目录下有一个
memcached.exe。
在
Windows的命令行(
cmd命令进入命令行)窗口进入该目录,首先运行:
memcached.exe
-
d install
上面这行表示安装
Memcached为服务,这样才能正常运行。接着运行如下这样来启动
Memcached,还可指定
-l参数,表示启动的
IP,
-m表示缓存大小:
memcached.exe
-
d start
若指定了
-m,则表示缓存大小为
-m后的数字,单位是
M,例如:
memcached.exe –l
127.0
.
0.1
–m
32
-
d start
运行参考如下图所示:
2.2 Java
客户端的安装
下载地址为:
https://github.com/gwhalin/Memcached-Java-Client
下载页面参考如下:
在上图中点击右侧区域的“Downloads
”,弹出的下载小窗口如下图:
当前最新的版本是
2.5.2,点击“
java_memcached-release_2.5.2.zip”下载。下载后解压,目录结构如下图所示:
在应用中,需要将“
java_memcached-release_2.5.2.jar”包拷贝到
Java项目中。
3
、
Memcached
的使用
3.1
创建项目
在
MyEclipse中创建一个名为
memcacheddemo的测试项目,
src放源代码,
bin放
classes文件,
lib放
jar包,并将
java_memcached-release_2.5.2.jar拷贝到
lib目录中,目录结构如下:
3.2 SockIOPool
类及其常用方法
SockIOPool是
socket连接池类,常用方法如下:
l
setServers(String[] servers):设置服务器信息数组;
l
setWeights(String[] weights):设置服务器权重数组;
l
setInitConn(int count):设置初始连接数;
l
setMinConn(int minConn):设置最小连接数;
l
setMaxConn(int maxConn):设置最大连接数;
l
setMaxIdle(long arg0):设置最大处理时间;
l
setMaintSleep(long arg0):主线程的睡眠时间;
l
initialize():初始化连接池。
3.3 MemCachedClient
类及其常用方法
MemCachedClient类用于对
Memcached内存对象缓存系统进行操作,常用方法如下:
l
add(String key, Object value):添加一个键值对到缓存中;
l
add(String key, Object value,Date expires):添加一个键值对到缓存中,并设置其超时时间;
l
set(String key, Object value):在缓存中设置一个键的值;
l
set(String key, Object value, Date expires):在缓存中设置一个键的值,并设置其超时时间;
l
get(String key):获得某个键的值。
l
incr(String key):为某个键上的值执行
+1操作;
l
decr(String key):为某个键上的值执行
-1操作;
l
replace(String key, String value):将某个键的值替换成新的值;
l
replace(String key, String value, Date expires):将某个键的值替换成新的值,并设置其超时时间。
3.4
使用实例
在
memcacheddemo工程的源码目录创建测试的
Java类
MemcachedTest,该类的代码参考如下:
import
java.util.Date;
import
com.danga.MemCached.MemCachedClient;
import
com.danga.MemCached.SockIOPool;
/** */
/**
* 使用memcached的缓存测试类.
*
@author
阿蜜果
*/
public
class
MemcachedTest
{
//
创建全局的唯一实例
protected
static
MemCachedClient mcc
=
new
MemCachedClient();
protected
static
MemcachedTest memCached
=
new
MemcachedTest();
//
设置与缓存服务器的连接池
static
{
//
服务器列表和其权重
String[] servers
=
{
"
127.0.0.1:11211
"
}
;
Integer[] weights
=
{
3
}
;
//
获取socket连接池的实例对象
SockIOPool pool
=
SockIOPool.getInstance();
//
设置服务器信息
pool.setServers(servers);
pool.setWeights(weights);
//
设置初始连接数、最小和最大连接数以及最大处理时间
pool.setInitConn(
5
);
pool.setMinConn(
5
);
pool.setMaxConn(
250
);
pool.setMaxIdle(
1000
*
60
*
60
*
6
);
//
设置主线程的睡眠时间
pool.setMaintSleep(
30
);
//
设置TCP的参数,连接超时等
pool.setNagle(
false
);
pool.setSocketTO(
3000
);
pool.setSocketConnectTO(
0
);
//
初始化连接池
pool.initialize();
//
压缩设置,超过指定大小(单位为K)的数据都会被压缩
mcc.setCompressEnable(
true
);
mcc.setCompressThreshold(
64
*
1024
);
}
/** */
/**
* 保护型构造方法,不允许实例化
*/
protected
MemcachedTest()
{
}
/** */
/**
* 获取唯一实例.
*
@return
*/
public
static
MemcachedTest getInstance()
{
return
memCached;
}
/** */
/**
* 添加一个指定的值到缓存中.
*
@param
key 键
*
@param
value 值
*
@return
在缓存中若该key不存在,并成功添加返回true,否则将返回false
*/
public
boolean
add(String key, Object value)
{
return
mcc.add(key, value);
}
/** */
/**
* 添加一个键值对到缓存中.
*
@param
key 键
*
@param
value 值
*
@param
expires 超时时间
*
@return
在缓存中若该key不存在,并成功添加返回true,否则将返回false
*/
public
boolean
add(String key, Object value, Date expires)
{
return
mcc.add(key, value, expires);
}
/** */
/**
* 将某个键的值改变成新值,首先需要保证该键存在.
*
@param
key 键
*
@param
value 值
*
@return
成功返回true,失败返回false
*/
public
boolean
replace(String key, Object value)
{
return
mcc.replace(key, value);
}
/** */
/**
* 将某个键的值改变成新值,首先需要保证该键存在.
*
@param
key 键
*
@param
value 值
*
@param
expires 超时时间
*
@return
成功返回true,失败返回false
*/
public
boolean
replace(String key, Object value, Date expires)
{
return
mcc.replace(key, value, expires);
}
/** */
/**
* 添加一个指定的值到缓存中.
*
@param
key
*
@param
value
*
@return
成功返回true,否则返回false
*/
public
boolean
set(String key, Object value)
{
return
mcc.set(key, value);
}
/** */
/**
* 添加一个指定的值到缓存中,并设置其超时时间.
*
@param
key 键
*
@param
value 值
*
@param
expires 超时时间
*
@return
成功返回true,否则返回false
*/
public
boolean
set(String key, Object value,
int
expires)
{
return
mcc.set(key, value, expires);
}
/** */
/**
* 根据指定的关键字获取对象.
*
@param
key
*
@return
返回value
*/
public
Object get(String key)
{
return
mcc.get(key);
}
/** */
/**
* 将指定key的value值+1,将返回最后的value值
*
@param
key
*
@return
返回最后的value值
*/
public
long
incr(String key)
{
return
mcc.incr(key);
}
/** */
/**
* 将指定key的value值-1,将返回最后的value值
*
@param
key
*
@return
返回最后的value值
*/
public
long
decr(String key)
{
return
mcc.decr(key);
}
/** */
/**
* 测试方法
*
@param
args
*/
public
static
void
main(String[] args)
{
MemcachedTest cache
=
MemcachedTest.getInstance();
cache.set(
"
count
"
,
123
);
System.out.println(
"
count=
"
+
cache.get(
"
count
"
));
boolean
flag
=
cache.add(
"
schedule_2
"
,
"
0
"
);
System.out.println(
"
flag=
"
+
flag);
System.out.println(
"
schedule_2=
"
+
cache.get(
"
schedule_2
"
));
}
}
运行结果为:
count
=
123
flag
=
true
schedule_2
=
0
4
、附录
《
Memcached Java客户端编程》:
http://sailinglee.javaeye.com/blog/752847
分享到:
相关推荐
Memcached是一个高性能的分布式的内存对象缓存系统.它的缓存是一种分布式的,也就是可以允许不同主机上的多个用户同时访问这个缓存系统,这种方法不仅解决了共享内存只能是单机的弊端,同时也解决了数据库检索的压力...
Memcached是什么? Memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。
分布式缓存系统C#应用实例,提高网站负载量。
这里需要解释说明一下,很多开发者觉得Memcached是一种分布式缓存系统,但是其实Memcached服务端本身是单实例的,只是在客户端实现过程中可以根据存储的主键做分区存储,而这个区就是Memcached服务端的一个或者多个...
《NET版分布式缓存Memcached测试实例.docx》 《Memcached管理及_.NET_开发.doc》 《memcached-win32-1.4.4-14.zip》 《安装Memcached及Memcached配置.doc》 《Linux部署》 简介 memcached是一套分布式的快取...
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的...
缘起: 在数据驱动的web开发中,经常要重复从数据库中取出相同的数据,这种重复极大的增加了数据库负载。缓存是解决这个问题的好办法。 本资源包含服务端和客户端文件,以及使用教程,代码实例。
一直在学习关注大访问量网站的缓存是如何实现,之前看过Memcached的资料,忙于没有时间来真正测试一下,本文测试分布式缓存Memcached的环境如下:(两台电脑作为服务器)CPU:Inter(R)Pentium(R)4CPU2.8G内存:...
主要介绍了分布式缓存软件Memcached的Java客户端使用,Memcached在GitHub上开源,作者用其Windows平台下的版本进行演示,需要的朋友可以参考下
本文实例讲述了Memcached缓存系统的介绍、安装以及应用方法。分享给大家供大家参考,具体如下: 一. memcached 是什么?...memcached是一个高性能的、分布式内存对象缓存系统,应用广泛。 通过缓存数据库查询结果,
Memcached是高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。Memcached由Danga Interactive开发,用于提升LiveJournal.com访问速度的。LJ每秒动态页面访问量几千次,用户700万...
memcached是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度,memcached 使用了“Key=>Value”方式组织数据,可以允许不同主机上的多个用户同时访问这个缓存系统,...
用memcached实现 Hibernate4二级缓存的实例源码。
memcached是一套分布式的高速缓存系统,由LiveJournal的Brad Fitzpatrick开发,但被许多网站使用。这是一套开放源代码软件,以BSD license授权发布。 memcached缺乏认证以及安全管制,这代表应该将memcached服务器...
Memcached是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度和可扩展性。 系统环境:CentOS 7.2 64位 Apache2.4.33 安装libevent依赖库 wget ...
《决战Nginx系统卷:高性能Web服务器详解与运维》 的最后一部分是关于Nginx使用缓存技术的方法,共列举了Nginx使用的五大缓存,特别是广泛使用的代理缓存、Memcached和Varnish,另外对于Memcached服务器的使用贯穿...
Memcache(内存,缓存) : 是一个高性能的分布式的内存对象缓存系统。通过在内存里维护一个巨大的hash表。 (key=value) Hash表 key value mystr “abc” myarr Array(“aa”, “cc”); object Object值 ...
《决战Nginx系统卷:高性能Web服务器详解与运维》 的最后一部分是关于Nginx使用缓存技术的方法,共列举了Nginx使用的五大缓存,特别是广泛使用的代理缓存、Memcached和Varnish,另外对于Memcached服务器的使用贯穿...
由国内著名技术社区联合推荐的2012年IT技术力作:《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》,即将上架发行,此书从Web应用、数据备份与恢复、网络存储应用、运维监控与性能优化、集群高级应用等...