redis 消息队列
redis
1,list 型,天生为消息队列准备的
class queue{
private function do($redis)
{
$theQueue = $redis->blpop(['queue'],0);
if ($theQueue) {
//队列业务逻辑处理代码
echo $theQueue[1]; //消息体
AwardCard::create([
'awardId'=>1,
'no'=>1,
'secret'=>$theQueue[1],
'term'=> null
]);
}
$this->do($redis);
}
public function show()
{
$redis = new \Redis();
$redis->connect('localhost', 6379);
$redis->auth("123456");
$this->do($redis);
}
}
lpush rpush 左右插入 lpop rpop 左右读取并删除
blpop brpop左右读取并删除(读取不到就一直处于等待状态,直到读取成功),防止 lpop,rpop 没有消息时不停轮询读取
注意:a,用个线程跑上述代码,blpop,brpop等待过程中,redis可能连接超时中断,需要捕捉异常,再次发起请求,b,blpop,brpop的键可以是多个,按照这些键值先后读取,利用这种特性可以做队列优先级
2,pub/sub 消息订阅法
<?php
class redisSubscribeQueue {
function callback($instance, $channelName, $message)
{
echo $channelName, "==>", $message, PHP_EOL;
}
//php e:\WWW\MyLumen\public\exe.php redisSubscribeQueue
public function show()
{
$redis = new \Redis();
$redis->pconnect('localhost', 6379);
$redis->auth("123456");
// $a = '$this->callback';
$redis->subscribe(['test'], function($instance, $channelName, $message){
// var_dump((array)$instance);
//$instance空对象
//一直挂着,下面是业务逻辑,收到消息也不会停止
echo $channelName, "==>", $message, PHP_EOL;
});
// self::callback('a','b','c');
}
}
(new redisSubscribeQueue())->show();
浙公网安备 33010602011771号