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

原创 2008年10月31日 12:49:00

                         如何对memcache的数据(key-value)进行遍历操作
                                                                                                                  作者:孙立
                                                                                                                  来源:http://blog.csdn.net/sunli1223

 什么是memcache

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

为什么要遍历

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

如何遍历memcache

   stats命令

 memcache的stats命令包括:

1.        stats  <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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服务器

1.jpg
执行stats items命令,可以看到出现 很多的items行。
2.jpg
执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。
下图为执行后的结果,item后面的字符串为key

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

4.jpg  
       到这里,你也许明白了怎么去遍历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.        for($i=0,$len=count($items);$i<$len;$i++){

9.            $number=$items[$i]['number'];

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操作那么高效。

对memcache的数据(key-value)进行遍历

下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现 ...
  • wangjiuwang
  • wangjiuwang
  • 2016-10-25 20:35:30
  • 754

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

什么是memcache         memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据...
  • yyggwan
  • yyggwan
  • 2014-05-30 15:12:12
  • 378

python的memcache使用如果对key设置了一个int型

如果对key设置了int型,会出现不可预知的错误,这个问题纠结了我好久,最终还是加了个str(),切忌切忌...
  • qiushi888
  • qiushi888
  • 2013-08-29 22:59:51
  • 707

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

1. PHP实现: 参考资料:http://www.cnblogs.com/sunli/archive/2008/11/01/1324153.html $port = 11211; $host...
  • kunshan_shenbin
  • kunshan_shenbin
  • 2012-06-01 20:13:43
  • 1197

Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、

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

Memcached使用总结之:使用Python操作memcache

Python连接memcached的库有很多,处于简单以及高效的原则,最终选择了pymemcache, 优点 完全实现了memcached text协议对于send/recv操作可以配...
  • sun7545526
  • sun7545526
  • 2016-06-08 12:01:55
  • 7207

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

如何对memcache的数据(key-value)进行遍历操作 什么是memcache         memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的...
  • wepe12
  • wepe12
  • 2016-09-17 11:08:58
  • 167

程序遍历memcache中的所有key-value

如何对memcache的数据(key-value)进行遍历操作                                                                    ...
  • daiyan_csdn
  • daiyan_csdn
  • 2017-01-12 15:34:13
  • 465

python处理key-value脚本

实现目标:把key-value配置文件解析,并根据解析内容执行一定的命令操作 (注意:配置文件可能是key=value或者key=value1 value2.···的形式) V1.0代码如下(后续继续...
  • qq_21794823
  • qq_21794823
  • 2017-12-26 19:14:48
  • 334

python 字典操作提取key,value

python 字典操作提取key,value dictionaryName[key] = value 1.为字典增加一项 2.访问字典中的值 3、删除字典中的一项 4、遍历字典 ...
  • HHTNAN
  • HHTNAN
  • 2017-08-14 17:24:27
  • 25929
收藏助手
不良信息举报
您举报文章:如何对memcache的数据(key-value)进行遍历操作
举报原因:
原因补充:

(最多只允许输入30个字)