如何对memcache的数据(key-value)进行遍历操作.files
2016-09-17 11:08
555 查看
如何对memcache的数据(key-value)进行遍历操作
什么是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服务器
图片1
执行stats items命令,可以看到出现 很多的items行。
图片2
执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。
下图为执行后的结果,item后面的字符串为key
图片3
通过上面列出的key我们就可以遍历所有的数据了,下面我们取出某一条数据,key为Uc!uLh的数据。
图片4
到这里,你也许明白了怎么去遍历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操作那么高效。相关文章推荐
- 艾伟:如何对memcache的数据(key-value)进行遍历操作
- [转载]如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 如何对memcache的数据(key-value)进行遍历操作
- 对memcache的数据(key-value)进行遍历操作
- 对memcache的数据(key-value)进行遍历
- 使用php Memcache模块如何正确遍历所有KEY以及VALUE
- java 中如何遍历hashMap的key所对应的value?
- KeyValuePair<byte, string> 类型的数据如何绑定到ComboBox控件上
- SQL使用游标遍历多层table获取每行的数据进行操作
- 这两个类是java中进行key-value存储、查询的常用类,如果我们学习过哈希算法就会知道key-value查询的效率依赖于如何存储,换句话说,如果存的好,拿出来就容易,存的不好,拿出来就不方便。两
- 如何对SQL Server数据表和数据库进行迭代操作
- 如何在 ASM 存储中使用 Data Pump (expdp impdp)进行数据导出导入操作