Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它经过在内存中缓存数据和对象来减小读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,可是客户端能够用任何语言来编写,并经过memcached协议与守护进程通讯。可是它并不提供冗余(例如,复制其hashmap条目);当某个服务器S中止运行或崩溃了,全部存放在S上的键/值对都将丢失。html
Memcached官方:http://danga.com/memcached/java
关于Memcached的介绍请参考:Memcached深度分析数据库
下载Windows的Server端windows
下载地址:http://code.jellycan.com/memcached/缓存
安装Memcache Server(也能够不安装直接启动)服务器
1. 下载memcached的windows稳定版,解压放某个盘下面,好比在c:\memcached
2. 在CMD下输入 "c:\memcached\memcached.exe -d install" 安装.
3. 再输入:"c:\memcached\memcached.exe -d start" 启动。NOTE: 之后memcached将做为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。分布式
若是下载的是二进制的版本,直接运行就能够了,能够加上参数来加以设置。memcached
经常使用设置:
-p <num> 监听的端口
-l <ip_addr> 链接的IP地址, 默认是本机
-d start 启动memcached服务
-d restart 重起memcached服务
-d stop|shutdown 关闭正在运行的memcached服务
-d install 安装memcached服务
-d uninstall 卸载memcached服务
-u <username> 以<username>的身份运行 (仅在以root运行的时候有效)
-m <num> 最大内存使用,单位MB。默认64MB
-M 内存耗尽时返回错误,而不是删除项
-c <num> 最大同时链接数,默认是1024
-f <factor> 块大小增加因子,默认是1.25
-n <bytes> 最小分配空间,key+value+flags默认是48
-h 显示帮助post
我已经将java的memcache客户端打包了,能够到这个地址下载:性能
http://download.csdn.net/detail/cdnight/6897533
下面是关于如何使用这个客户端来添加缓存,修改缓存的程序示例:
(源自网上示例,可是某些地方改了一下省得新版本的客户端出错了)
package EWeb.Base.Tools;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import EWeb.Base.Config.AppConfig;
import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;
/**
* 警告:这个类是memcache的客户端,用于帮助存取缓存内容,
* 要使用请先配置好memcache服务器,而且运行该服务器,
* 正如要读写数据库时候须要安装数据库并运行数据库服务。
* */
public class MemCachedManager {
// 建立全局的惟一实例
protected static MemCachedClient mcc = new MemCachedClient();
protected static MemCachedManager memCached = new MemCachedManager();
// 设置与缓存服务器的链接池
static {
// 服务器列表和其权重
/**
*这里是根据配置文件读取memcache服务器的ip地址,不够不用这么麻烦,调试状态能够直接设为:127.0.0.1:11211
*/
String _memcacheServerIP=AppConfig.getMemCachedServerIP();
String[] servers = {_memcacheServerIP};
Integer[] weights = { 3 };
// 获取socke链接池的实例对象
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 MemCachedManager()
{
}
/**
* 获取惟一实例.
* @return
*/
public static MemCachedManager getInstance()
{
return memCached;
}
/**
* 添加一个指定的值到缓存中.
* @param key
* @param value
* @return
*/
public boolean add(String key, Object value)
{
return mcc.add(key, value);
}
public boolean add(String key, Object value, Date expiry)
{
return mcc.add(key, value, expiry);
}
public boolean replace(String key, Object value)
{
return mcc.replace(key, value);
}
public boolean replace(String key, Object value, Date expiry)
{
return mcc.replace(key, value, expiry);
}
/**
* 根据指定的关键字获取对象.
* @param key
* @return
*/
public Object get(String key)
{
return mcc.get(key);
}
public static void main(String[] args)
{
MemCachedManager cache = MemCachedManager.getInstance();
long startDate=System.currentTimeMillis();
try{
cache.add("testkey","您好吗?");
String str=cache.get("testkey").toString();
System.out.println(str);
System.out.println(cache.get("testkey2"));
}
catch (Exception ed){
ed.printStackTrace();
}
}
}
运行之后出现这个结果:
ok,windows下面的java+memcache调试环境已经整合完成。