Redis实战系列(2) 使用List结构构造高效的队列系统

Redis 提供了brpop blpop brpoplpush三个阻塞命令来监听一个List数据结构。下面是php脚本

server.php
$redis = new Redis();
$redis->connect('127.0.0.1');
while(true){
	$data = $o->brpop(array('key1','key2'), 30);
	var_dump($data); //array('key1'=>'data1')
}

client.php
$redis = new Redis();
$redis->connect('127.0.0.1');
for($i=0;$i<10000; $i++){
	$redis->lpush('key1','data'.$i);
}

而使用brpoplpush可以构建一个可靠的队列,brpop将元素从list中弹出,如果没有处理完毕那这个事件就消失了,如果用brpoplpush,就可以讲正在处理的key弹出到另外一个list结构中,这样在进程处理完成时调用lrem来删除这个元素。php代码:

server.php
$redis = new Redis();
$redis->connect('127.0.0.1');
while(true){
	$data = $o->brpoplpush('key1','key2'), 30);
	var_dump($data); //data1
	//some process
	$o->lrem($key2,$data);
}

client.php
$redis = new Redis();
$redis->connect('127.0.0.1');
for($i=0;$i<10000; $i++){
	$redis->lpush('key1','data'.$i);
}


最新的redis2.6版本中支持lua,而redis的作者也给出了一个用lua脚本来实现可靠队列的方法,链接: http://antirez.com/post/250


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值