`
godsend_jin
  • 浏览: 39980 次
  • 性别: 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" ));

    }

 

}

 

分享到:
评论

相关推荐

    php的Memcache方法介绍及应用实例

    Memcache PHP 扩展将为访问缓存提供一个简单的应用程序接口 (API)。要使用缓存,需要调用 API 来确定先前是否已缓存了对象。如果已经缓存,只需检索该对象并继续进行处理。否则,转至数据库、获取必需的数据、将其...

    PHP MemCached 高级缓存应用代码

    Memcache常用方法 Memcache::add — 添加一个值,如果已经存在,则返回false Memcache::addServer — 添加一个可供使用的服务器地址 Memcache::close — 关闭一个Memcache对象 Memcache::connect — 创建一个...

    Memcache2.8

    memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。Memcache是danga.com的一个项目,最早是...

    memcache-2.2.5

    memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。Memcache是danga.com的一个项目,最早是...

    LswMemcacheBundle:Web调试工具栏中的用于Memcache教义缓存和会话存储的Symfony软件包

    LswMemcacheBundle 如果要针对高负载和/或低负载时间优化Web应用程序,Memcache是​​必不可少的工具。 它可以管理您的会话数据,而无需在Web或数据库服务器上执行磁盘I / O。 您也可以将其作为网站的中央对象存储来...

    Memcache Windows版本,含32位、64位批处理可直接安装

    Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。

    nhibernate分布式缓存dll

    elocity是微软推出的分布式缓存解决方案,为开发可扩展性,可用的,高性能的应用程提供支持,可以缓存各种类型的数据,如CLR对象、XML、二进制数据等,并且支持集群模式的缓存服务器。Velocity也将集成在.NET ...

    cl-memcached:Memcached 对象缓存系统的快速、线程安全接口

    根据主页: memcached是一种高性能、分布式内存对象缓存系统,本质上是通用的,但旨在通过减轻数据库负载来加速动态 Web 应用程序。 在 SBCL、CCL 和 CMUCL 上测试。 全局变量*memcache* 大多数命令都将此作为后备...

    Linux下memcache编译安装与基本使用教程

    memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。目前用memcache解决互联网上的大用户读取是非常流行的一种用法,在互联网企业中有着广泛的应用。 memcache是一套...

    EasyMVC 框架.zip

    专为企业和个人打造的安全稳定,并发性...9、内置文件缓存,memcache等缓存 10、支持pdo 和 传统函数操作数据库,分别适合于企业和个人用户 EasyMVC目标 打造安全稳定,并发性高,海量数据处理能力的国内优秀PHP 框架

    网站加速VPS篇 memcache和memcached安装方法

     Memcache是一个自由和开放源代码、高性能、分配的内存对象缓存系统。用于加速动态web应用程序,减轻数据库负载。  它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后...

    Memcached v1.5.4 For Windows (附带Memcached和libevent源码两个版本)

    Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的...

    memcached-1.2.1-win32

    memcache服务器群,一款分布式缓存产品,很多大型网站在应用; 它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable。因为...

    memcached-1.4.4.tar.gz

    memcache服务器群,一款分布式缓存产品,很多大型网站在应用; 它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable。因为...

    phpfastcachepro:PHP高性能对象缓存APC MemCached文件WinCache-开源

    phpFastCache是​​一种高性能的分布式对象缓存系统,本质上是通用的,但旨在通过减轻数据库负载来加速动态Web应用程序。 支持:具有许多API函数的APC,文件,MemCache,Memcached,WinCache,PDO。 更改缓存系统时...

    分布式缓存Memcached实例

    Memcached是什么? Memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。

    memcached原理和使用详解

    资源名称:memcached原理和使用详解内容简介: Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库...

    pop-cache:Pop缓存组件

    根据服务器环境和可用资源,应用程序可以使用以下缓存适配器之一: APC(缓存服务) 文件(磁盘上的目录) Memcache(缓存服务) Redis(缓存服务) 会话(会话中的短期缓存) db(数据库缓存) pop-cache是的组件...

    memcached 1.4.5

    是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。编译版 x64系统适用

Global site tag (gtag.js) - Google Analytics