什么是memcache
memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视 频、文件以及数据库检索的结果等。Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被很多大型的网站采用。目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。
为什么要遍历
目前,用到memcache的公司和网站也越来越多。Memcache的客户端操作一般都只提供了get,set等简单的操作,这些操作都是非常高效的。 虽然memcache是个key-value存储的系统,但是在某些时候,我们可能需要遍历memcache的数据。
如何遍历memcache
stats命令
memcache的stats命令包括:
1.
stats
2.
statsreset
3.
statsmalloc
4.
statsmaps
5.
statssizes
6.
statsslabs
7.
statsitems
8.
statscachedumpslab_idlimit_num
9.
statsdetail[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. 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操作那么高效。
新浪微博:http://t.sina.com.cn/sunli1223
Twitter: http://twitter.com/sunli1223
凤凰: http://t.ifeng.com/sunli
分享到:
相关推荐
在实际应用中,遍历Memcache可能用于执行批量操作,如更新、清理过期数据或者进行数据统计。然而,频繁的全量遍历可能会增加网络和CPU的负载,所以应谨慎使用。 为了更深入了解Memcache的使用,可以参考`Memcached-...
七、如何遍历memcache 八、在PHP程序中使用Memcached a 在PHP安装Memcache扩展 b 在PHP什么地方使用memcache c 实例 九、Memcache的安全(不让别人访问) 安装. 然后开始 memcached -d start
Memcache是一种分布式内存缓存系统,用于存储临时数据,以减少对数据库的直接访问。当面临每分钟数万次访问量,需要记录IP、PV(页面浏览量)和UV(独立访客量)等数据时,如果直接将这些数据实时写入数据库,可能...
Memcache 只支持 key value 存储方式,Redis 支持更多的数据类型,比如 Key value,hash,list,set,zset; - D. Memcache 自身不支持持久化,Redis 支持持久化。 - **正确答案**:B - **答案解析**:Memcache ...
4. 调用`statsCacheDump()`方法获取特定slab的详细数据,其中包括key-value对。 5. 从这些详细数据中提取key,并添加到`keyList`中。 6. 最后,计算遍历所有key所需的时间,并返回key列表。 需要注意的是,这种方法...
支持数据遍历,方便对存储内容进行监视 支持条件查询,筛选出满足条件的KEY或VALUE 数组、JSON等序列化字符反序列显示 兼容memcache协议的其他服务,如Tokyo Tyrant (遍历功能除外) 支持服务器连接池,多服务器...
支持数据遍历,方便对存储内容进行监视 支持条件查询,筛选出满足条件的KEY或VALUE 数组、JSON等序列化字符反序列显示 兼容memcache协议的其他服务,如Tokyo Tyrant (遍历功能除外) 支持服务器连接池,多服务器...
add()方法接受四个参数,分别是键(key)、值(value)、标志(flag)和过期时间(expire time)。如果指定的键不存在,则会添加该键值对到缓存中;如果键已存在,则不会有任何操作。另外,还可以选择MEMCACHE_COMPRESSED...
- PUT原理:通过key的哈希码找到对应的桶,遍历桶中的链表或红黑树,如果找到key相同则覆盖value,否则插入链表头部(或红黑树相应位置)。 - GET原理:同样根据key的哈希码找到桶,遍历链表或红黑树,查找key并...
哈希表由多个通过网络连接的server组成,用户无需关心数据的存储位置,只需调用接口进行操作。memcached使用LRU(Least Recently Used)算法管理内存,通过删除或设置过期时间来淘汰不再使用的数据,确保内存的有效...