windows下安裝memcache及java客戶端調用

一.Memcached windows 下安裝與測試

   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

2、下載java版本的memcache客戶端及使用

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

相關文章
相關標籤/搜索