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調試環境已經整合完成。