如何遍历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$host='192.168.15.225'
$port=11211
$mem=new Memcache()
$mem->connect($host,$port)
$items=$mem->getExtendedStats (‘items’)
$items=$items["$host:$port"]['items']
foreach($items as $key=>$values){
$number=$key
$str=$mem->getExtendedStats ("cachedump",$number,0)
$line=$str["$host:$port"]
if( is_array($line) && count($line)>0){
foreach($line as $key=>$value){
echo $key.'=>'
print_r($mem->get($key))
echo "\r\n"
}
}
}?>
扩展功能
由此可以实现查找memcache某个前缀的key的数据,或者查询某些value的key。甚至实现数据库的like功能。请注意:遍历memcache的 *** 作并没有memcache的get *** 作那么高效。
redis和memecache的不同在于:1、存储方式:
memecache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小
redis有部份存在硬盘上,这样能保证数据的持久性。
2、数据支持类型:
redis在数据支持上要比memecache多的多。
3、使用底层模型不同:
新版本的redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。
4、运行环境不同:
redis目前官方只支持LINUX 上去行,从而省去了对于其它系统的支持,这样的话可以更好的把精力用于本系统 环境上的优化,虽然后来微软有一个小组为其写了补丁。但是没有放到主干上
http://blog.163.com/wz_pk007/blog/static/17062705020132123917817/
1、Redis和Memcache都是将数据存放在内存中,都是内存数据库。不过memcache还可用于缓存其他东西,例如图片、视频等等。
2、Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。
3、虚拟内存--Redis当物理内存用完时,可以将一些很久没用到的value 交换到磁盘
4、过期策略--memcache在set时就指定,例如set key1 0 0 8,即永不过期。Redis可以通过例如expire 设定,例如expire name 10
5、分布式--设定memcache集群,利用magent做一主多从redis可以做一主多从。都可以一主一从
6、存储数据安全--memcache挂掉后,数据没了;redis可以定期保存到磁盘(持久化)
7、灾难恢复--memcache挂掉后,数据不可恢复redis数据丢失后可以通过aof恢复
8、Redis支持数据的备份,即master-slave模式的数据备份。
http://www.infoq.com/cn/articles/tq-why-choose-redis
实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加,和访问量的持续增长,我们遇到了很多问题:
MySQL需要不断进行拆库拆表,Mem
存数据库时set或delete,取时候先get,没取到再查数据库。memcache可以减少项目对数据库的“读” *** 作。
举个例子:
function getUser($id)
{
$user = $memcache->get("user_{$id}")
if (!empty($user)) return $user
$user = $db->getById($id)
$memcache->set("user_{$id}", $user)
return $user
}
function setUser($id, $user)
{
$db->updateUser($id, $user)
$memcache->set("user_{$id}", $user)
// 或者 $memcache->delete("user_{$id}")
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)