1、
Memcached
介绍
Memcached是高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。
Memcached由
Danga Interactive开发,用于提升
LiveJournal.com访问速度的。
LJ每秒动态页面访问量几千次,用户
700万。
Memcached将数据库负载大幅度降低,更好的分配资源,更快速访问。
Memcached的最新版是采用
c语言进行开发和设计的,它是一个应用软件,是作为缓存服务器的服务器端运行在服务器上的,需要使用特定的语言编写客户端与其进行通信来进行数据的缓存和获取。
在系统中,通常将
Memcached安装运行在服务器上,然后通过对需要的数据进行缓存,所有数据的缓存设置和存取操作,以及数据的更新后替换操作全部需要程序来进行。
2、
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
分享到:
相关推荐
本资料包包含“Memcached实例与文档”,是学习和理解Memcached工作原理及应用的重要资源。 一、Memcached的基本概念 Memcached基于键值对(key-value)存储,提供简单的文本协议,易于与其他编程语言集成。它的设计...
安装Memcached服务器通常有两种方式:通过源码编译或使用预编译的二进制包。在“安装_包”文件中,可能包含了预编译的二进制包,你可以根据操作系统进行相应的安装步骤。例如,在Linux上,解压下载的包,然后运行`...
**Memcached与Java实例文档详解** Memcached是一种高性能、分布式内存对象缓存系统,它能够减轻数据库的负担,提高Web应用的性能。...通过提供的"Memcached实例与文档"压缩包,你可以进一步学习和实践这些知识。
### Net Memcached安装及使用说明 #### 一、概述 Net Memcached是一种高效的分布式缓存系统,主要用于硬盘缓存服务,能够充分利用硬盘空间来存储缓存信息,从而直接提升访问速度,同时不会占用过多的内存资源。这...
本文将详细解析如何在Java项目中使用Memcached,包括其配置方法以及一个具体的示例代码,旨在帮助开发者深入理解并掌握这一技术。 ### 一、Memcached简介 Memcached是一种开源的高性能内存键值存储系统,主要用于...
**标题:“memcached java简单实例”** 在Java开发中,我们常常会遇到缓存的需求,以提高应用程序的性能。Memcached是一款高效的分布式内存对象缓存系统,它能够将数据存储在内存中,从而减少对数据库的访问。这篇...
本实例将带你深入了解如何安装 Memcached 客户端,并学习如何使用它来缓存数据以及清除缓存内容。 ### 一、安装 Memcached 在开始使用 Memcached 之前,你需要先在服务器上安装它。安装过程可能因操作系统而异,...
5. **使用MemCached客户端**:在代码中,你可以创建一个MemcachedClient实例并开始操作缓存。以下是一个简单的示例: ```csharp var cache = new MemcachedClient(); string key = "exampleKey"; string value =...
4. **集群扩展**:当单个Memcached实例无法满足需求时,可以通过增加更多服务器构成集群。 **六、与其他缓存系统的比较** 与Redis相比,Memcached更简单,专注于高速缓存,而Redis提供了更多的数据结构和持久化...
一个完整的memcached使用实例,memcached安装在windows上,使用java代码测试memcached是否安装部署成功,包括编译好的exe 及 jar文件,使用请看readme.txt文件
以下是一个简单的Java实例,演示如何使用Spymemcached连接到Memcached服务器并执行基本操作: 1. **添加依赖** 首先,你需要在项目中添加Spymemcached的依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下...
在Linux环境下,可以通过包管理器(如apt-get或yum)安装Memcached。安装完成后,需要启动服务,并可以通过命令行工具`memcached`进行配置,例如设置监听端口、最大内存等参数。 ### 3. 使用Memcached进行缓存操作 ...
本文将详细介绍如何安装和使用 Memcached。 首先,安装 Memcached 需要依赖 `libevent-dev` 库。在 Linux 系统(如 Ubuntu 或 Debian)上,你可以使用 `apt` 包管理器来安装它: ```bash sudo apt install ...
分布式缓存Memcached实例详解 Memcached是一款由Danga Interactive公司设计并开发的高效、分布式内存对象缓存系统。它的主要目标是减轻数据库的负担,提高动态应用程序的响应速度,通过将数据存储在内存中,使得...
可以启动多个memcached实例,但需要注意每个实例的监听端口不能相同。 #### 五、通过脚本对Memcached进行管理 为了方便管理memcached,可以编写shell脚本来实现启动、停止以及监控等功能。 1. **启动memcached...
创建Memcached集群通常涉及配置多个实例,以及使用客户端库支持分布式存储。 总结来说,Memcached是跨平台的缓存解决方案,适用于Windows和Linux环境。通过正确配置和使用,它可以显著提升Web应用的性能,减少对...
java Memcached客户端代码,整合到Spring,提供Util工具类 代码片段: public class MemcachedUtils { private static boolean setExp(String key, Object value, Date expire) { boolean flag = false; try { ...
5. **分布式**:Memcached支持基于键的分布式策略,这意味着多个客户端可以同时访问同一个Memcached实例,且数据自动分散在各个节点上,无需额外的分布式协调机制。 **Memcached的安装与使用**: 1. 安装Memcached...
有实例,window环境下安装包,安装文档,使用文档,LINUX下说明文档等等,基本上所有的东西都全了.如果还有少的,请大家帮忙补充谢谢.如果是在WINDOWS下测试,安装一下安装包然后执行实例就可以了,命令窗口不要...
2. **初始化连接**:在代码中,首先需要创建一个Memcached客户端实例,通常使用Spymemcached或XMemcached等客户端库,指定memcached服务器的地址和端口。 3. **操作缓存**:现在你可以开始进行基本的缓存操作,如`...