memcache是一个高性能的分布式的内存对象缓存系统,经过在内存里维护一个统一的巨大的hash表,它可以用来存储各类格式的数据,包括图像、视 频、文件以及数据库检索的结果等。Memcache是danga.com的一个项目,最先是为 LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被不少大型的网站采用。目前全世界很多人使用这个缓存项目来构建本身大负载的网站,来分担数据库的压力。php
目前,用到memcache的公司和网站也愈来愈多。Memcache的客户端操做通常都只提供了get,set等简单的操做,这些操做都是很是高效的。 虽然memcache是个key-value存储的系统,可是在某些时候,咱们可能须要遍历memcache的数据。 数据库
memcache的stats命令包括:缓存
1. stats 服务器
2. stats reset 分布式
3. stats malloc 性能
4. stats maps 测试
5. stats sizes 网站
6. stats slabs spa
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. 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操做那么高效。