• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
CaoJianbang
邦哥
博客园    首页    新随笔    联系   管理    订阅  订阅

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();


posted @ 2021-05-08 09:53  CaoJianbang  阅读(238)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3