如何遍历memcached里面所有key的命令
来源:互联网 发布:初中语文软件 编辑:程序博客网 时间:2024/06/07 03:34
为什么要遍历 目前,用到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数据的代码,其他语言可以参考代码自己实现。
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 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数据的代码,其他语言可以参考代码自己实现。
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; }
0 0
- 如何遍历memcached里面所有key的命令
- 如何遍历memcached里面所有key的命令
- 遍历memcached所有的key
- Ruby遍历MemCached的key
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- Redis遍历所有key的两个命令 -- KEYS 和 SCAN
- as3 如何遍历类里面所有的属性
- Memcached中获取所有的key
- 遍历获取JSONObject的所有Key
- java遍历文件夹里面的所有文件
- 遍历一个布局里面所有的控件
- C#如何遍历一个文件夹下面所有的文件、包括子文件夹里面的文件?
- C++遍历所有IE浏览器,得到里面的所有元素
- C++遍历所有IE浏览器,得到里面的所有元素
- java里面如何去获得map里面的key-value;
- Android 遍历Hashmap里面的key 和value
- memcached实战系列(五)Memcached: List all keys 查询所有的key
- Webview浅析
- CMFCShellListCtrl使用方法
- RTP 简单的发送端程序和接收端程序
- 使用Makefile链接so库文件
- 时间复杂度的计算
- 如何遍历memcached里面所有key的命令
- [leetcode]32 Length of Last Word
- 【checkio】the Moore neighbourhood
- [Windows]_[MacOSX]_[获取程序的执行文件所在路径(目录)]
- listView条目不能点击问题
- 算法训练 2的次幂表示
- 使用MapWinGis ActiveX控件在shapefile文件图层上画直线
- OJ 系列之字符串转换为整数
- 【jQuery】利用表单的序列化根据name取表单,做表单的验证