`
sacredlove
  • 浏览: 12179 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

memcache java客户端编程

阅读更多
   Memcached是高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。Memcached由Danga Interactive开发,用于提升LiveJournal.com访问速度的。LJ每秒动态页面访问量几千次,用户700万。Memcached将数据库负载大幅度降低,更好的分配资源,更快速访问。

    上网baidu了很多东西,几乎都差不多,而且基于java的说的很少,所有只有在研究了各个其他语言类的应用后再来尝试在java上进行简单的操作应用。先从memcached上进行说明,memcached的最新版是采用c语言进行开发和设计的,据说旧版的是采用perl语言开发的,而且它是一个应用软件来的,是作为缓存服务器的服务器端运行在服务器上的,需要使用特定的语言编写客户端与其进行通信来进行数据的缓存和获取。通常我们是把 memcached安装运行在web服务器上,然后通过对需要的数据进行缓存,据我目前所知,所有数据的缓存设置和存取操作,以及数据的更新后替换操作全部需要程序来进行,而不是自动进行的(自动不知道能不能成功,呵呵)。下面从一个实际的例子来应用memcached。

    首先到http://danga.com/memcached/ 下载memcached的windows版本和java客户端jar包,目前最新版本是memcached-1.2.1-win32.zip和 java_memcached-release_1.6.zip,分别解压后即可!首先是安装运行memcached服务器,我们将memcached- 1.2.1-win32.zip解压后,进入其目录,然后运行如下命令:

c:>memcached.exe -d install
c:>memcached.exe -l 127.0.0.1 -m 32 -d start

    第一行是安装memcached成为服务,这样才能正常运行,否则运行失败!第一行是启动memcached的,作为测试我们就简单的只分配32M内存了,然后监听本机端口和以守护进行运行。执行完毕后,我们就可以在任务管理器中见到memcached.exe这个进程了。好了,我们的服务器已经正常运行了, 下面我们就来写java的客户端连接程序。
package utils.cache;

import java.util.Date;

import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;


/**
* 使用memcached的缓存实用类.
*
* @author 铁木箱子
*
*/
public class MemCached
{
    // 创建全局的唯一实例
    protected static MemCachedClient mcc = new MemCachedClient();
   
    protected static MemCached memCached = new MemCached();
   
    // 设置与缓存服务器的连接池
    static {
        // 服务器列表和其权重
        String[] servers = {"127.0.0.1:11211"};
        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 MemCached()
    {
       
    }
   
    /**
     * 获取唯一实例.
     * @return
     */
    public static MemCached 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)
    {
        MemCached cache = MemCached.getInstance();
        cache.add("hello", 234);
        System.out.print("get value : " + cache.get("hello"));
    }
}

   

memcached的缓存实用类
import java.util.Date;

import com.danga.MemCached.MemCachedClient;
import com.danga.MemCached.SockIOPool;


/**
* 使用memcached的缓存实用类.
*
* @author 铁木箱子
*
*/
public class MemCached
{
    // 创建全局的唯一实例
    protected static MemCachedClient mcc = new MemCachedClient();
   
    protected static MemCached memCached = new MemCached();
   
    // 设置与缓存服务器的连接池
    static {
        // 服务器列表和其权重
        String[] servers = {"127.0.0.1:11211"};
        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 MemCached()
    {
       
    }
   
    /**
     * 获取唯一实例.
     * @return
     */
    public static MemCached 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)
    {
        MemCached cache = MemCached.getInstance();
        cache.add("hello", 234);
        System.out.print("get value : " + cache.get("hello"));
TBean tb = new TBean();
tb.setName("铁木箱子");
cache.add("bean", tb);
TBean tb1 = (TBean)cache.get("bean");
System.out.print("name=" + tb1.getName());
tb1.setName("铁木箱子_修改的");
tb1 = (TBean)cache.get("bean");
System.out.print("name=" + tb1.getName());
    }
}

那么我们就可以通过简单的像main方法中操作的一样存入一个变量,然后再取出进行查看,我们可以看到先调用了add,然后再进行get,我们运行一次后,234这个值已经被我们存入了memcached的缓存中的了,我们将main方法中红色的那一行注释掉后,我们再运行还是可以看到get到的 value也是234,即缓存中我们已经存在了数据了。

    对基本的数据我们可以操作,对于普通的POJO而言,如果要进行存储的话,那么比如让其实现java.io.Serializable接口,因为 memcached是一个分布式的缓存服务器,多台服务器间进行数据共享需要将对象序列化的,所以必须实现该接口,否则会报错的 。比如我们写一个简单的测试Bean如下:

class TBean implements java.io.Serializable
{
    private static final long serialVersionUID = 1945562032261336919L;
   
    private String name;

    public String getName()
    {
        return name;
    }

    public void setName(String name)
    {
        this.name = name;
    }
我们首先把TBean的一个实例放入缓存中,然后再取出来,并进行名称的修改,然后我们再取这个对象,我们再看其名称,发现修改的对象并不是缓存中的对象,而是通过序列化过来的一个实例对象,这样我们就无须担心对原生类的无意修改导致缓存数据失效了,呵呵~~看来我也是多此一想啊。所以这表明从缓存中获取的对象是存入对象的一个副本,对获取对象的修改并不能真正的修改缓存中的数据,而应该使用其提供的replace等方法来进行修改 。 


}
分享到:
评论
1 楼 Yinny 2012-07-22  
好文章,学习了~~~

相关推荐

    memcache的配置及使用——memcache及其客户端telnet

    除了telnet,还有许多编程语言的客户端库,如PHP的`memcache`和`memcached`扩展,Python的`pylibmc`,Java的`spymemcached`等。这些库提供了更方便的API来操作Memcached,如`set`、`get`、`delete`方法,并支持序列...

    memcached linux安装说明+ java客户端调用例子

    **memcached** 是一款高性能、分布式...综上所述,memcached在Linux上的安装和Java客户端的调用涉及了系统管理、网络服务、编程接口等多个方面的知识。了解并熟练掌握这些步骤,有助于构建高效、可扩展的Web应用程序。

    memcached服务端已经多个客户端

    4. **客户端库**: 存在多种语言(如Python、Java、PHP、Ruby等)的客户端库,便于与memcached服务端进行通信。 5. **安装与配置**: 安装memcached服务端涉及编译源码、设置配置文件(如`memcached.conf`)以及启动...

    spring memcache 集成使用

    - **下载Java客户端**:下载`java_memcached-release_2.6.1.zip`作为Java端的客户端库,以便于在Java程序中操作Memcache服务。 ##### 2. 配置Spring环境 - **创建Spring配置文件**:根据描述中提供的示例,新建...

    memcache也spring,hibernate的配置

    6. **xmemcache与xmemcache-spring**:xmemcache是一个Java客户端库,用于连接和操作Memcached服务器。xmemcache-spring是其与Spring框架的整合,提供Spring的缓存抽象,使得在Spring应用中配置和使用Memcached更...

    memcached for java client 例子

    4. **基本操作**:Java客户端库提供了一系列API,如`set()`用于存储数据,`get()`用于获取数据,`delete()`用于删除数据,`incr()`和`decr()`用于原子性地增加或减少数值。 5. **数据过期策略**:memcached中的数据...

    MemCache开发说明文档

    MemCache支持多种编程语言的客户端库,如PHP、Python、Java、Ruby等,使得它能广泛应用于各种技术栈的项目中。在实际应用中,合理地分配和管理缓存数据,以及调整MemCache的内存大小和过期策略,是优化系统性能的...

    Java memcache缓存实现for Windows.pdf

    Memcached Java客户端库通过这些方法允许开发者灵活地配置和管理与Memcache服务器的连接,从而实现高效的数据缓存。在实际应用中,正确配置这些参数是优化性能的关键,需要根据具体业务需求进行调整。例如,设置合理...

    demo_memcache_ieda

    2. **XMemcached**:另一个流行的Java客户端,提供了线程安全的API,支持多种协议(如Binary Protocol和Text Protocol)。XMemcached提供了更丰富的功能,比如支持批量操作,监控和统计,以及更高效的连接管理。 **...

    memcache分布式缓存的使用

    1. **连接与断开**:在编程中,首先要建立与Memcache服务器的连接,设置主机和端口信息。完成操作后,记得正确关闭连接。 2. **存储操作**:通过键值对的方式进行数据存储,包括`set`(设置)、`add`(添加,如果键...

    Memcache 全面剖析,Memcache 教程

    1. **语言支持**:Memcache 提供了多种编程语言的客户端库,包括 PHP、Python、Java、Ruby、C++ 等,方便在不同环境中集成。 2. **基本操作**:添加(set)、获取(get)、删除(delete)、替换(replace)、增加...

    memcache.zip 缓存jar包

    3. **引入Java客户端**:将解压出的Java client jar包添加到项目的类路径中,以便于在代码中引用。 4. **编程接入**:在Java代码中,通过创建Memcached客户端实例,设置服务器地址和端口,然后就可以进行put(存储)...

    windows本地开启memcache服务

    - 一旦Memcache服务运行起来,开发人员可以使用各种编程语言(如PHP、Python、Java、C#等)编写代码与之交互,存储和检索数据,从而提升应用性能。 通过以上步骤,你便可以在Windows上成功开启并使用Memcache服务...

    memcache软件和+教程

    - **客户端库**:Memcache支持多种编程语言,如PHP、Python、Java、Ruby等,有相应的客户端库进行连接和操作。 - **命令接口**:Memcache提供了简单的文本协议,可以通过telnet命令行工具直接与服务交互,进行存取...

    MemCache Client User Guide

    本指南主要涵盖了客户端的基础设置以及集群配置,适用于熟悉Java编程并希望通过MemCache优化应用性能的开发者。 首先,使用MemCache客户端需要依赖以下几个库文件: 1. commons-logging-1.0.4.jar 或更高版本:提供...

    Memcache需要的依赖包

    6. **跨语言支持**:Memcache提供了多种编程语言的客户端库,包括PHP、Python、Java、Ruby、C++等,使得各种语言的开发者都能方便地使用。 在alisoft-xplatform-asf-cache中,可能包含了一些阿里巴巴内部的特性和...

    服务器缓存服务memcache

    - **简单易用**:Memcache使用TCP协议,API简洁,支持多种编程语言,如PHP、Python、Java、Ruby等。 - **动态扩展**:当内存不足时,Memcache会自动删除最近最少使用的数据(LRU策略)。 - **键值对存储**:数据...

    maven-spring-memcache

    Spring是Java开发中最流行的轻量级应用框架之一,它提供了全面的事务管理、依赖注入、AOP(面向切面编程)等功能,使得开发更简洁、可测试和可维护。在Spring中集成Memcache,可以利用其强大的DI(Dependency ...

    memcache window 安装下载

    在Windows环境下,你可以使用PHP、Python、Java等编程语言的客户端库与Memcache交互。例如,在PHP中,你可以使用`memcached`扩展来操作缓存: ```php $memcached = new Memcached(); $memcached->addServer('...

    Java开发中的Memcache原理及实现

    3. 协议简单:Memcached使用基于文本行的简单协议,方便各种编程语言的客户端进行通信。 4. 并发处理:Memcached支持多线程并发处理请求,保证高并发场景下的性能。 二、Java与Memcached的结合 在Java开发中,...

Global site tag (gtag.js) - Google Analytics