如何对memcache的数据(key-value)进行遍历操作

from:http://www.cnblogs.com/sunli/archive/2008/11/01/1324153.html


什么是memcache

        memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视 频、文件以及数据库检索的结果等。Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被很多大型的网站采用。目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。

为什么要遍历

   目前,用到memcache的公司和网站也越来越多。Memcache的客户端操作一般都只提供了get,set等简单的操作,这些操作都是非常高效的。   虽然memcache是个key-value存储的系统,但是在某些时候,我们可能需要遍历memcache的数据。     

如何遍历memcache

   stats命令

 memcache的stats命令包括:

1.         stats  

2.         stats reset  

3.         stats malloc  

4.         stats maps  

5.         stats sizes  

6.         stats slabs  

7.         stats items  

8.         stats cachedump slab_id limit_num  

9.         stats detail [on|off|dump]   

通过命令完成遍历

       通过这些stats命令我们就可以完成memcache存储的内容的遍历,OK,下面我们通过telnet直接连接到memcache通过这些命令来完成相关的操作。 
      telnet到192.168.15.225(局域网测试机器)的memcache服务器


执行stats items命令,可以看到出现 很多的items行。 

执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。 
下图为执行后的结果,item后面的字符串为key

 
 通过上面列出的key我们就可以遍历所有的数据了,下面我们取出某一条数据,key为Uc!uLh的数据。

  
       到这里,你也许明白了怎么去遍历memcache的数据了。 

代码实现

       下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现。

下面贴上一段php 实现的遍历memcache 数据的代码,其他语言可以参考代码自己实现。

 

1.         <?php

2.         $host = '192.168.15.225' ;

3.         $port =11211;

4.         $mem = new  Memcache();

5.         $mem ->connect( $host , $port );

6.         $items = $mem ->getExtendedStats ( ‘items’ );

7.         $items = $items [ "$host:$port" ][ 'items' ];

8.        foreach($items as $key=>$values){

9.              $number=$key; ;

10.           $str = $mem ->getExtendedStats ( "cachedump" , $number ,0);

11.           $line = $str [ "$host:$port" ];

12.           if ( is_array( $line ) && count( $line )>0){

13.               foreach ( $line   as   $key => $value ){

14.                  echo  $key . '=>' ;

15.                  print_r( $mem ->get( $key ));

16.                  echo  "/r/n" ;

17.              }

18.          }

19.      }

20.      ?>

扩展功能

     由此可以实现查找memcache某个前缀的key的数据,或者查询某些value的key。甚至实现数据库的like功能。请注意:遍历memcache的操作并没有memcache的get操作那么高效。

新浪微博:http://t.sina.com.cn/sunli1223  
Twitter: http://twitter.com/sunli1223  
凤凰: http://t.ifeng.com/sunli

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值