`
leiwuluan
  • 浏览: 707156 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

Memcached 高性能的分布式内存对象缓存系统 Memcached的安装、使用实例

 
阅读更多

        Memcached 是一个高性能的分布式内存 对象缓存系统,用于动态Web 应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached 基于一个存储键/值对的hashmap 。其守护进程(daemon )是用C写的,但是客户端 可以用任何语言来编写,并通过memcached协议与守护进程通信。但是它并不提供冗余(例如,复制其hashmap条目);当某个服务器S停止运行或崩溃了,所有存放在S上的键/值对都将丢失。

  Memcached 由Danga Interactive 开发,其最新版本发布于2010年,作者为Anatoly Vorobey 和Brad Fitzpatrick。用于提升LiveJournal . com访问速度的。LJ每秒动态页面访问量几千次,用户700万。Memcached 将数据库负载大幅度降低,更好的分配资源,更快速访问。\

 

 

源地址 :http://baike.baidu.com/view/794242.htm

 

 

阿蜜果

源地址: http://www.blogjava.net/amigoxie/archive/2011/02/15/344381.html

Memcached 的安装

2.1 主程序的安装

一般的服务器都是采用 Linux,笔者只是讲述在 Windows上如何安装 Memcached,在 Linux上的安装请参考网上其它资料。

Windows版本的下载地址为: http://code.jellycan.com/memcached/

当前 win32的最新版本是 1.2.6,下载页面参考如下:
   

在上图中点击“ memcached-1.2.6-win32-bin.zip ”进入下载页面,下载后,将其解压到 D盘下,解压后的 D:"memcached-1.2.6-win32-bin目录下有一个 memcached.exe

Windows的命令行( cmd命令进入命令行)窗口进入该目录,首先运行:

memcached.exe  - d install

上面这行表示安装 Memcached为服务,这样才能正常运行。接着运行如下这样来启动 Memcached,还可指定 -l参数,表示启动的 IP -m表示缓存大小:

memcached.exe  - d start

若指定了 -m,则表示缓存大小为 -m后的数字,单位是 M,例如:

memcached.exe –l  127.0 . 0.1  –m  32   - d start

运行参考如下图所示:
  

2.2 Java 客户端的安装

下载地址为: https://github.com/gwhalin/Memcached-Java-Client

下载页面参考如下:
  

         在上图中点击右侧区域的“Downloads ”,弹出的下载小窗口如下图:
   

         当前最新的版本是 2.5.2,点击“ java_memcached-release_2.5.2.zip”下载。下载后解压,目录结构如下图所示:
   

         在应用中,需要将“ java_memcached-release_2.5.2.jar”包拷贝到 Java项目中。

3 Memcached 的使用

3.1 创建项目

MyEclipse中创建一个名为 memcacheddemo的测试项目, src放源代码, bin classes文件, lib jar包,并将 java_memcached-release_2.5.2.jar拷贝到 lib目录中,目录结构如下:
  

3.2 SockIOPool 类及其常用方法

         SockIOPool socket连接池类,常用方法如下:

setServers(String[] servers):设置服务器信息数组;

setWeights(String[] weights):设置服务器权重数组;

setInitConn(int count):设置初始连接数;

setMinConn(int minConn):设置最小连接数;

setMaxConn(int maxConn):设置最大连接数;

setMaxIdle(long arg0):设置最大处理时间;

setMaintSleep(long arg0):主线程的睡眠时间;

initialize():初始化连接池。

3.3 MemCachedClient 类及其常用方法

         MemCachedClient类用于对 Memcached内存对象缓存系统进行操作,常用方法如下:

add(String key, Object value):添加一个键值对到缓存中;

add(String key, Object value,Date expires):添加一个键值对到缓存中,并设置其超时时间;

set(String key, Object value):在缓存中设置一个键的值;

set(String key, Object value, Date expires):在缓存中设置一个键的值,并设置其超时时间;

get(String key):获得某个键的值。

incr(String key):为某个键上的值执行 +1操作;

decr(String key):为某个键上的值执行 -1操作;

replace(String key, String value):将某个键的值替换成新的值;

replace(String key, String value, Date expires):将某个键的值替换成新的值,并设置其超时时间。

3.4 使用实例

         memcacheddemo工程的源码目录创建测试的 Java MemcachedTest,该类的代码参考如下:

import  java.util.Date;

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

/** */ /**
 * 使用memcached的缓存测试类.
 * 
@author  阿蜜果
 
*/

public   class  MemcachedTest  {
    
//  创建全局的唯一实例
     protected   static  MemCachedClient mcc  =   new  MemCachedClient();

    
protected   static  MemcachedTest memCached  =   new  MemcachedTest();

    
//  设置与缓存服务器的连接池
     static   {
        
//  服务器列表和其权重
        String[] servers  =   { " 127.0.0.1:11211 " } ;
        Integer[] weights 
=   { 3 } ;

        
//  获取socket连接池的实例对象
        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  MemcachedTest()  {

    }


    
/** */ /**
     * 获取唯一实例.
     * 
@return
     
*/

    
public   static  MemcachedTest getInstance()  {
        
return  memCached;
    }


    
/** */ /**
     * 添加一个指定的值到缓存中.
     * 
@param  key 键
     * 
@param  value 值
     * 
@return  在缓存中若该key不存在,并成功添加返回true,否则将返回false
     
*/

    
public   boolean  add(String key, Object value)  {
        
return  mcc.add(key, value);
    }


    
/** */ /**
     * 添加一个键值对到缓存中.
     * 
@param  key 键
     * 
@param  value 值
     * 
@param  expires 超时时间
     * 
@return  在缓存中若该key不存在,并成功添加返回true,否则将返回false
     
*/

    
public   boolean  add(String key, Object value, Date expires)  {
        
return  mcc.add(key, value, expires);
    }


    
/** */ /**
     * 将某个键的值改变成新值,首先需要保证该键存在.
     * 
@param  key 键
     * 
@param  value 值
     * 
@return  成功返回true,失败返回false
     
*/

    
public   boolean  replace(String key, Object value)  {
        
return  mcc.replace(key, value);
    }


    
/** */ /**
     * 将某个键的值改变成新值,首先需要保证该键存在.
     * 
@param  key 键
     * 
@param  value 值
     * 
@param  expires 超时时间
     * 
@return  成功返回true,失败返回false
     
*/

    
public   boolean  replace(String key, Object value, Date expires)  {
        
return  mcc.replace(key, value, expires);
    }


    
/** */ /**
     * 添加一个指定的值到缓存中.
     * 
@param  key
     * 
@param  value
     * 
@return  成功返回true,否则返回false
     
*/

    
public   boolean  set(String key, Object value)  {
        
return  mcc.set(key, value);
    }

    
    
/** */ /**
     * 添加一个指定的值到缓存中,并设置其超时时间.
     * 
@param  key 键
     * 
@param  value 值
     * 
@param  expires 超时时间
     * 
@return  成功返回true,否则返回false
     
*/

    
public   boolean  set(String key, Object value,  int  expires)  {
        
return  mcc.set(key, value, expires);
    }

    
    
/** */ /**
     * 根据指定的关键字获取对象.
     * 
@param  key
     * 
@return  返回value
     
*/

    
public  Object get(String key)  {
        
return  mcc.get(key);
    }


    
/** */ /**
     * 将指定key的value值+1,将返回最后的value值
     * 
@param  key 
     * 
@return  返回最后的value值
     
*/

    
public   long  incr(String key)  {
        
return  mcc.incr(key);
    }

    
    
/** */ /**
     * 将指定key的value值-1,将返回最后的value值
     * 
@param  key 
     * 
@return  返回最后的value值
     
*/

    
public   long  decr(String key)  {
        
return  mcc.decr(key);
    }

    
    
/** */ /**
     * 测试方法
     * 
@param  args
     
*/

    
public   static   void  main(String[] args)  {
        MemcachedTest cache 
=  MemcachedTest.getInstance();
        cache.set(
" count " 123 );
        System.out.println(
" count= "   +  cache.get( " count " ));
        
boolean  flag  =  cache.add( " schedule_2 " " 0 " );
        System.out.println(
" flag= "   +  flag);
        System.out.println(
" schedule_2= "   +  cache.get( " schedule_2 " ));
    }

}

      运行结果为:

count = 123
flag
= true
schedule_2
= 0

4 、附录

         Memcached Java客户端编程》:

http://sailinglee.javaeye.com/blog/752847

 

 

 

分享到:
评论

相关推荐

    MemCached高性能分布式的内存对象缓存系统应用说明[收集].pdf

    Memcached 是一个开源的、高性能的分布式内存对象缓存系统,设计用于缓解数据库负载,提高Web应用程序的响应速度。它通过在内存中存储数据,创建一个全局的哈希表,来临时保存各种格式的数据,例如数据库查询结果、...

    phpFastCache是一种高性能分布式的对象缓存系统

    phpFastCache是一款针对PHP开发的高效分布式对象缓存系统,它的主要目的是提高动态Web应用的性能,通过将频繁访问的数据暂存到缓存中,减少对数据库的直接操作,从而降低数据库负载。这款开源库在Web开发领域广泛...

    C#/.net分布式缓存系统Memcached 实例

    Memcached是一个高性能的分布式的内存对象缓存系统.它的缓存是一种分布式的,也就是可以允许不同主机上的多个用户同时访问这个缓存系统,这种方法不仅解决了共享内存只能是单机的弊端,同时也解决了数据库检索的压力...

    分布式缓存Memcached实例

    分布式缓存Memcached实例详解 Memcached是一款由Danga Interactive公司设计并开发的高效、分布式内存对象缓存系统。它的主要目标是减轻数据库的负担,提高动态应用程序的响应速度,通过将数据存储在内存中,使得...

    Memcached分布式缓存

    ### Memcached分布式缓存 #### 一、Memcached的基础 **1.1 Memcached是什么?** Memcached是一款高性能、分布式内存对象缓存系统,旨在通过减轻数据库负担来加速动态网络应用的速度。它通过在内存中缓存数据和...

    Memcached分布式缓存系统的应用.pdf

    ### Memcached分布式缓存技术特点 Memcached作为一个开源的高性能内存对象缓存系统,具有以下特点: 1. **协议简单**:Memcached服务器与客户端之间采用基于文本行的协议进行通信,支持多种方式获取数据。协议的...

    第四十四章:Memcached高性能对象缓存1

    Memcached 是一款高性能、分布式内存对象缓存系统,最初由 LiveJournal 开发团队设计,主要用于缓解数据库负载,提升网站访问速度。它将所有数据存储在内存中,以一个大型哈希表的形式管理,支持各种类型的数据。...

    memcached//分布式数据缓存

    6. **分布式存储**:虽然单个Memcached实例的内存有限,但可以通过在多台机器上部署多个实例,使用一致性哈希等算法实现分布式缓存,扩大存储容量并提高可用性。 7. **源码分析**:对于深入理解其工作原理,可以...

    MemcachedDemo----分布式缓存系统C#应用实例

    Memcached是一款开源、高性能、分布式的内存对象缓存系统,它设计的目标是简化数据存储和检索过程,通过将数据存储在内存中,避免了磁盘I/O操作,从而提高了数据访问的速度。C# 是一种广泛使用的编程语言,尤其在...

    memcached缓存使用演示

    Memcached是一款高性能、分布式内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。它通过将数据存储在内存中,使得数据的读取速度大大提高,尤其在处理高并发请求时表现卓越。 ### ...

    .net memcached 分布式缓存应用类库

    .NET Memcached 分布式缓存应用类库是用于在.NET环境...通过正确使用.NET Memcached分布式缓存应用类库,开发者能够构建出高效、可扩展的应用,显著提升服务响应速度,降低数据库压力,提高整体系统的性能和用户体验。

    分布式缓存系统Memcached学习心得.zip

    Memcached是一款高效、轻量级的分布式内存对象缓存系统,它旨在减轻数据库负载,提升应用性能。本资源针对Memcached的学习,包含了服务端部署、客户端使用以及实战代码示例,为开发者提供了全面的了解和实践途径。 ...

    memcached linux windows 安装 使用 缓存 集群

    Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。通过在内存中存储常用数据,Memcached能够快速响应客户端请求,避免了频繁的磁盘I/O操作。 ...

    Memcached实例与文档

    Memcached是一种高性能、分布式内存对象缓存系统,用于在分布式环境中加速动态Web应用程序。它通过存储数据和对象在内存中,减少对数据库的访问来提高应用程序的响应速度。本资料包包含“Memcached实例与文档”,是...

    memcached分布式工具

    Memcached是一种高性能、分布式内存对象缓存系统,用于在分布式计算环境中缓解数据库负载,提高应用程序的性能。它通过将数据存储在内存中,为需要快速访问的数据提供高速存取服务。在大型网站和高流量应用中,...

    大型分布式系统中的缓存架构

    Memcached是一个高性能的分布式内存对象缓存系统,采用LRU策略进行数据淘汰。它不支持分布式集群,但可以通过多实例部署实现类似效果。 **Redis** Redis是另一种流行的分布式缓存,支持多种数据结构,适用于复杂的...

    memcached 分布式内存

    Memcached 是一套由 danga.com 开发的高效、分布式的内存对象缓存系统,其主要目标是在高流量的动态应用程序中减轻数据库的负载,从而提升整体系统的性能。这套系统的工作原理是将数据存储在内存中,以便快速访问,...

    memcached实例

    Memcached 是一个高性能的分布式内存对象缓存系统,它能够将数据存储在内存中,以减少数据库的访问压力,提高应用的响应速度。本实例将带你深入了解如何安装 Memcached 客户端,并学习如何使用它来缓存数据以及清除...

    memcached_1.2.5.zip服务器缓存调节工具

    2. **分布式**: 分布式意味着多个独立的Memcached实例可以在多台机器上运行,通过网络相互协作,共同提供缓存服务。这样可以实现负载均衡,提高系统的可扩展性和容错性。 3. **内存对象缓存**: Memcached将数据存储...

    Hibernate4二级缓存实例(源码)

    2. **memcached**:这是一个高性能、分布式的内存对象缓存系统,用于临时存储数据。它的特点是简单、轻量级,适用于处理大量小数据项的缓存需求。 3. **Hibernate与memcached集成**:将memcached作为Hibernate二级...

Global site tag (gtag.js) - Google Analytics