Memcached 连接,memcached里面所有key的命令

https://www.runoob.com/memcached/memcached-install.html

我们可以通过 telnet 命令并指定主机ip和端口来连接 Memcached 服务。

语法

telnet HOST PORT

命令中的 HOST 和 PORT 为运行 Memcached 服务的 IP 和 端口。

实例

以下实例演示了如何连接到 Memcached 服务并执行简单的 set 和 get 命令。

本实例的 Memcached 服务运行的主机为 127.0.0.1(本机) 、端口为 11211。

telnet 127.0.0.1 11211

Trying 127.0.0.1...

Connected to 127.0.0.1.

Escape character is '^]'.

set foo 0 0 3                                                   保存命令

bar                                                             数据

STORED                                                          结果

get foo                                                         取得命令

VALUE foo 0 3                                                   数据

bar                                                             数据

END                                                             结束行

quit                                                            退出

为什么要遍历 目前,用到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服务器

如何遍历memcached里面所有key的命令X

 
执行stats items命令,可以看到出现 很多的items行。
如何遍历memcached里面所有key的命令
执行stats cachedump 3 0命令。这里的3表示上面图中items后面的数字,0标示显示全部的数据,如果是1就标示只显示1条。
下图为执行后的结果,item后面的字符串为key
如何遍历memcached里面所有key的命令
通过上面列出的key我们就可以遍历所有的数据了,下面我们取出某一条数据,key为Uc!uLh的数据。
如何遍历memcached里面所有key的命令
到这里,你也许明白了怎么去遍历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可能当时设计的时候就把它定位为内存性的kv结构的缓存系统。所以没有持久化到磁盘的命令,也没有查看所有key的值得命令。可能觉得没必要吧,你要是缓存1个G内存的数据,自己都头大,还敢看。但是近期确实需要查看商城的数据所有值,于是乎研究了一下。还别说还真有这个命令,只是隐藏的深而已。

需要还是连接到我们的服务器吧。

telnet 127.0.0.1 18887

stats items命令如下:看以参考之前的命令文章看具体的使用。效果如下:

这个命令告诉我们有三个key在这个卡槽里面。

继续输入命令如下:

stats cachedump 1 100  

参数的含义:第一个参数1 表示需要查看item的值 我们这里查看的是1,下图第一个标记就是。item的含义我们下一个章节讲解memcached存储原理和方式。

第二个参数表示需要查看多少个key的值,你可以输入你需要查看的具体值,我们这里查询的是100个。

执行效果如下图所示:

ok了,是不是很简单,很酸爽呢。


 

猜你喜欢

转载自blog.csdn.net/BlueBirdssh/article/details/91047557