`
godsend_jin
  • 浏览: 41797 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

MemCache对象缓存应用

    博客分类:
  • java
 
阅读更多

参考:http://my.oschina.net/u/273598/blog/100733?fromerr=QG2sQjeH

主要是参考别人的内容,把需要用到的资源给整合以下,方便自己或需要的同学使用....

 

一、需要引入jar包(附件中有):

      commons-pool-1.6.jar,

      java_memcached-release_2.6.6.jar,

      slf4j-api-1.7.5.jar,

      slf4j-simple-1.7.13.jar

      Memcached-Java-Client官网jar包的下载地址:

 

      https://github.com/gwhalin/Memcached-Java-Client/downloads

      当然也可以maven pom.xml配置引入,看个人项目需求了

      java_memcached-release_2.6.6.jar,这个jar包在maven中央库中未收录,所以如果使用的话需要先安装到maven库中,执行命令 mvn install:install-file  -Dfile=D:\java_memcached-release_2.6.6.jar -DgroupId=com.danga -DartifactId=memcached -Dversion=2.6.6 -Dpackaging=jar  -DgeneratePom=true 。这个时候应该在本地maven库中有看到相应的jar包,在项目中就可以直接使用了

      <dependency>

 <groupId>com.danga</groupId>

 <artifactId>memcached</artifactId>

 <version>2.6.6</version>

      </dependency>

      如果直接把jar包放到项目中也可以,以下配置

      <dependency>

<groupId>com.danga</groupId>

<artifactId>memcached</artifactId>

<version>2.6.6</version>

<scope>system</scope>

<systemPath>${project.basedir}/src/main/webapp/WEB-INF/lib/java_memcached-release_2.6.6.jar</systemPath>

      </dependency>

      其他jar包maven库中有收录就不用这么麻烦了,直接配置

      <dependency>

<groupId>commons-pool</groupId>

<artifactId>commons-pool</artifactId>

<version>1.6</version>

      </dependency>

 

      <dependency>

   <groupId>org.slf4j</groupId>

   <artifactId>slf4j-simple</artifactId>

   <version>1.7.13</version>

      </dependency>

      关于这个写法,可以到maven库去查询:http://search.maven.org/

二、以下是例子,需要先启动memcached.exe(附件中有)

      查看是否启动成功telnet 127.0.0.1 11211(根据自己的服务器来)

      stats items 列出所有key

      stats cachedump itemid 0 根据itemid列出对应key,第二个参数是长度,0表示所有 

      get id 通过key获取缓存内容

package org.andy.shop.service;

 

import java.util.Date;

 

import com.danga.MemCached.MemCachedClient;

import com.danga.MemCached.SockIOPool;

 

public class MemCachedManager {

 

// 创建全局的唯一实例

    protected static MemCachedClient mcc = new MemCachedClient();

     

    protected static MemCachedManager memCached = new MemCachedManager();

     

    // 设置与缓存服务器的连接池

    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();

  

    }

     

    /**

     * 保护型构造方法,不允许实例化!

     *

     */

    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();

        for (int i = 0; i < 3; i++) {

            cache.add("test"+i , "中国");

        }

        long endDate=System.currentTimeMillis();

          

        long nowDate=(endDate-startDate)/1000;

        System.out.println(nowDate);

        System.out.print( " get value : " + cache.get( "test0" ));

    }

 

}

 

分享到:
评论

相关推荐

    Memcache缓存技术,Memcache配置说明及其文件,PHP5.2.6版本内存缓存技术配置

    Memcache是一种广泛应用于Web开发中的分布式内存对象缓存系统,它可以临时存储数据,减少数据库的负载,提高应用程序的性能。在本主题中,我们将详细探讨Memcache缓存技术,特别是针对PHP5.2.6版本的配置以及在...

    asp memcache 解决缓存问题

    ASP Memcache 是一种在 ASP(Active Server Pages)环境中实现高效缓存管理的技术,它通过集成 Memcached 这个高性能的分布式内存对象缓存系统来提升应用程序的性能。Memcached 是一个广泛使用的开源软件,用于存储...

    MemCache和Redis缓存介绍

    1. **基本概念**:MemCache是一款开源的高性能、分布式内存对象缓存系统,主要用于减少数据库访问的负载。它通过将数据存储在内存中,实现快速读取,适用于处理大量数据的高并发场景。 2. **工作原理**:MemCache...

    java版memcache缓存管理与开发

    Memcache是一种高性能、分布式内存对象缓存系统,它通过减轻数据库负担来加速动态Web应用程序的速度。其主要功能是将部分数据存储在内存中,从而实现前端数据的快速存取。 #### 分布式Memcache应用 对于大型网站而...

    memcache分布式缓存的使用

    当应用需要数据时,首先尝试从Memcache中获取,如果存在则直接返回,不存在则从数据库中读取并存入Memcache,这一过程被称为缓存命中和缓存未命中的处理。Memcache采用哈希表结构,确保了高效的键查找,同时支持多...

    memcache分布式的对象缓存系统

    Memcache 是一款高性能的分布式对象缓存系统,其设计的核心理念是通过在内存中创建一个巨大的哈希表来实现快速的数据缓存,从而减少对数据库的频繁访问,提高应用程序的性能。这个系统采用C/S架构,由服务器端的...

    Memcache与微软缓存

    Memcache是一款高性能、分布式的内存对象缓存系统,最初设计用于加速动态Web应用,通过减少数据库负载来提升性能。它将数据存储在内存中,以键值对的形式供应用快速访问,适用于存储临时性的、非结构化的数据。 **...

    memcache数据库缓存.pdf

    Memcache是一个高性能、高并发的分布式内存缓存系统,主要用于缓解数据库读压力。它是由C语言编写的开源软件,设计简洁,代码量小,具有约2000行代码。Memcache主要作用是提高数据访问速度,尤其适用于处理大量热点...

    memcache缓存配置包(dll,memched,配置方法)

    1. **Memcached软件**: Memcached是Memcache的主要实现,它是一个高性能、分布式的内存对象缓存系统。它设计的目标是通过将数据存储在内存中,快速地为Web应用提供数据访问,避免频繁的数据库查询。Memcached服务器...

    memcache缓存分布式集群

    Memcache是一种广泛使用的高性能分布式内存对象缓存系统,主要用于减轻数据库的负载,通过将数据存储在内存中,实现快速访问。在大型应用中,单台Memcache服务器可能无法满足高并发和大容量的需求,这时就需要搭建...

    服务器缓存服务memcache

    Memcache是一种高性能、分布式内存对象缓存系统,它主要用于减轻数据库负载,提高Web应用的响应速度。Memcache基于一个简单的键值对存储模型,能够存储任何类型的数据,如字符串、整数、浮点数甚至是二进制数据。...

    Memcache缓存

    Memcache是一种开源的、高性能的分布式内存对象缓存系统,它的主要目标是为了减轻数据库的负担,提高网站的响应速度。Memcache通过在内存中缓存数据和对象来减少对数据库的访问次数,从而提升网站性能。它提供了一个...

    memcache.zip 缓存jar包

    Memcache是一种广泛应用于Web开发中的分布式内存缓存系统,它能有效地缓解数据库的负载,提高应用程序的性能。这个"memcache.zip"压缩包包含了运行和使用Memcache所需的组件,特别是针对Java开发者的client库。 ...

    Memcache缓存安装学习课件及源码

    Memcache是一种广泛应用于Web开发中的分布式内存对象缓存系统,它可以大大提高应用程序的性能,通过将数据存储在内存中,减少对数据库的访问次数,从而降低了系统的响应时间。本课件和源码旨在帮助你深入理解和实践...

    springmvc配置Memcache缓存Demo

    在这个"springmvc配置Memcache缓存Demo"中,我们将探讨如何在Spring MVC项目中集成Memcache,一个高性能的分布式内存对象缓存系统,以提升应用的性能。 首先,让我们了解Memcache的基本概念。Memcache是一个开源的...

    继上一版留言本并加入memcache缓存和pdo连接方式

    Memcache是一种广泛使用的分布式内存对象缓存系统,它可以临时存储数据,减少对数据库的访问频率,从而大大提高Web应用的响应速度。在本项目中,Memcache被用于存储留言数据,当用户请求留言信息时,首先会检查缓存...

    memcache数据库缓存

    Memcached是一种高性能的分布式内存对象缓存系统,它能够减轻数据库的压力,提高Web应用的响应速度。该系统最初由LiveJournal的Danga Interactive开发,现已被广泛应用在许多大型网站上,如Facebook、Twitter等。它...

    memcache缓存

    Memcached 是一款高性能、分布式内存对象缓存系统,它广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问的速度。作为一个轻量级的缓存解决方案,它通过在内存中存储数据来提供快速的数据访问,从而优化应用...

Global site tag (gtag.js) - Google Analytics