在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 val