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调试环境已经整合完成。

相关文章
相关标签/搜索