如何遍历memcached里面所有key的命令
2015-03-28 16:18
471 查看
为什么要遍历 目前,用到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服务器
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/1.jpg)
X
执行stats
items命令,可以看到出现 很多的items行。
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/2.jpg)
执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。
下图为执行后的结果,item后面的字符串为key
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/3.jpg)
通过上面列出的key我们就可以遍历所有的数据了,下面我们取出某一条数据,key为Uc!uLh的数据。
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/4.jpg)
到这里,你也许明白了怎么去遍历memcache的数据了。
代码实现 下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现。
下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现。
php:
java
public static Map getKeysForMap() throws UnsupportedEncodingException{
Map keylist=new HashMap(); //遍历statsItems 获取items:2:number=14 Map> statsItems=mcc.statsItems(); Map statsItems_sub=null; String statsItems_sub_key=null; int items_number=0; String server=null; //根据items:2:number=14,调用statsCacheDump,获取每个item中的key Map> statsCacheDump=null;
Map statsCacheDump_sub=null; String statsCacheDumpsub_key=null; String statsCacheDumpsub_key_value=null; for (Iterator iterator=statsItems.keySet().iterator();iterator.hasNext();) { server=(String) iterator.next(); statsItems_sub=statsItems.get(server); //System.out.println(server+'==='+statsItems_sub);
for (Iterator iterator_item=statsItems_sub.keySet().iterator();iterator_item.hasNext();) { statsItems_sub_key=(String)
iterator_item.next(); //System.out.println(statsItems_sub_key+':=:'+bb); //items:2:number=14 if (statsItems_sub_key.toUpperCase().startsWith('items:'.toUpperCase()) && statsItems_sub_key.toUpperCase().endsWith(':number'.toUpperCase())){ items_number=Integer.parseInt(statsItems_sub.get(statsItems_sub_key).trim());
//System.out.println(statsItems_sub_key+':=:'+items_number); statsCacheDump=mcc.statsCacheDump(new String[]{server},Integer.parseInt(statsItems_sub_key.split(':')[1].trim()), items_number); for (Iterator statsCacheDump_iterator=statsCacheDump.keySet().iterator();statsCacheDump_iterator.hasNext();)
{ statsCacheDump_sub=statsCacheDump.get(statsCacheDump_iterator.next()); //System.out.println(statsCacheDump_sub);
for (Iterator iterator_keys=statsCacheDump_sub.keySet().iterator();iterator_keys.hasNext();) { statsCacheDumpsub_key=(String) iterator_keys.next(); statsCacheDumpsub_key_value=statsCacheDump_sub.get(statsCacheDumpsub_key); //System.out.println(statsCacheDumpsub_key);//key是中文被编码了,是客户端在set之前编码的,服务端中文key存的是密文
//System.out.println(statsCacheDumpsub_key_value); keylist.put(URLDecoder.decode(statsCacheDumpsub_key, 'UTF-8'), new KeysBean(server,Long.parseLong(statsCacheDumpsub_key_value.substring(1, statsCacheDumpsub_key_value.indexOf('b;')-1).trim()),Long.parseLong(statsCacheDumpsub_key_value.substring(statsCacheDumpsub_key_value.indexOf('b;')+2,statsCacheDumpsub_key_value.indexOf('s]')-1).trim())));
}} } } } return keylist; }
虽然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服务器
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/1.jpg)
X
执行stats
items命令,可以看到出现 很多的items行。
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/2.jpg)
执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。
下图为执行后的结果,item后面的字符串为key
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/3.jpg)
通过上面列出的key我们就可以遍历所有的数据了,下面我们取出某一条数据,key为Uc!uLh的数据。
![](http://p.blog.csdn.net/images/p_blog_csdn_net/sunli1223/EntryImages/20081031/4.jpg)
到这里,你也许明白了怎么去遍历memcache的数据了。
代码实现 下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现。
下面贴上一段php实现的遍历memcache数据的代码,其他语言可以参考代码自己实现。
php:
java
public static Map getKeysForMap() throws UnsupportedEncodingException{
Map keylist=new HashMap(); //遍历statsItems 获取items:2:number=14 Map> statsItems=mcc.statsItems(); Map statsItems_sub=null; String statsItems_sub_key=null; int items_number=0; String server=null; //根据items:2:number=14,调用statsCacheDump,获取每个item中的key Map> statsCacheDump=null;
Map statsCacheDump_sub=null; String statsCacheDumpsub_key=null; String statsCacheDumpsub_key_value=null; for (Iterator iterator=statsItems.keySet().iterator();iterator.hasNext();) { server=(String) iterator.next(); statsItems_sub=statsItems.get(server); //System.out.println(server+'==='+statsItems_sub);
for (Iterator iterator_item=statsItems_sub.keySet().iterator();iterator_item.hasNext();) { statsItems_sub_key=(String)
iterator_item.next(); //System.out.println(statsItems_sub_key+':=:'+bb); //items:2:number=14 if (statsItems_sub_key.toUpperCase().startsWith('items:'.toUpperCase()) && statsItems_sub_key.toUpperCase().endsWith(':number'.toUpperCase())){ items_number=Integer.parseInt(statsItems_sub.get(statsItems_sub_key).trim());
//System.out.println(statsItems_sub_key+':=:'+items_number); statsCacheDump=mcc.statsCacheDump(new String[]{server},Integer.parseInt(statsItems_sub_key.split(':')[1].trim()), items_number); for (Iterator statsCacheDump_iterator=statsCacheDump.keySet().iterator();statsCacheDump_iterator.hasNext();)
{ statsCacheDump_sub=statsCacheDump.get(statsCacheDump_iterator.next()); //System.out.println(statsCacheDump_sub);
for (Iterator iterator_keys=statsCacheDump_sub.keySet().iterator();iterator_keys.hasNext();) { statsCacheDumpsub_key=(String) iterator_keys.next(); statsCacheDumpsub_key_value=statsCacheDump_sub.get(statsCacheDumpsub_key); //System.out.println(statsCacheDumpsub_key);//key是中文被编码了,是客户端在set之前编码的,服务端中文key存的是密文
//System.out.println(statsCacheDumpsub_key_value); keylist.put(URLDecoder.decode(statsCacheDumpsub_key, 'UTF-8'), new KeysBean(server,Long.parseLong(statsCacheDumpsub_key_value.substring(1, statsCacheDumpsub_key_value.indexOf('b;')-1).trim()),Long.parseLong(statsCacheDumpsub_key_value.substring(statsCacheDumpsub_key_value.indexOf('b;')+2,statsCacheDumpsub_key_value.indexOf('s]')-1).trim())));
}} } } } return keylist; }
相关文章推荐
- 如何遍历memcached里面所有key的命令
- java MemCachedClient遍历memcache中所有的key
- as3 如何遍历类里面所有的属性
- 使用php Memcache模块如何正确遍历所有KEY以及VALUE
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- java MemCachedClient遍历memcache中所有的key
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- C#如何遍历一个文件夹下面所有的文件、包括子文件夹里面的文件?
- c#如何实现对指定路径文件夹的遍历并复制里面所有文件到指定路径
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- java MemCachedClient遍历memcache中所有的key
- 如何遍历获得div里面所有a标签,并为每一个div添加自增的id和对应的事件
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- json对象转map方法之一,通过遍历json对象的所有key,取出value放入map
- 如何替换某文件中的所有的特定字符?---linux sed命令(文本编辑命令) (转载)
- 安卓学习笔记---如何保存数据到SharePreference里面,获取所有sp文件以及删除文件
- 如何一键删除ios 模拟器里面得所有app
- 遍历json对象的所有key,在使用json对象时,如果无法知道key,怎么通过key变量来获取值
- watir学习之—如何遍历页面所有的超链接
- Oracle命令--如何查看oracle中创建的所有目录