laravel扩展使用redis消息发布与订阅
业务场景
项目业务场景中需要去订阅兄弟部门的数据,技术栈这块经过商讨决定采用了redis发布publish和订阅subscribe的特性。由于项目是基于laravel,所以需要安装predis ,且正确配置redis链接,这里不再详细说明。
shell测试redis发布publish和订阅subscribe
1.小实例演示一下发布订阅
127.0.0.1:6379> publish ORDERID 10001
(integer) 1
127.0.0.1:6379> publish ORDERID 10002
(integer) 1
127.0.0.1:6379>
127.0.0.1:6379> subscribe ORDERID
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "ORDERID"
3) (integer) 1
1) "message"
2) "ORDERID"
3) "10001"
1) "message"
2) "ORDERID"
3) "10002"
结合laravel订阅消息并处理
#获取订阅到的消息
创建laravel的php artisan命令在handle
里执行监听代码
public function handle()
{
#订阅消息redis
$redis = new \Redis();
$redis->pconnect(Config("host"), Config("port"));
$redis->auth(Config("password"));
//订阅订单id ORDERID
$redis->subscribe(['ORDERID'], function($redis, $channel,$message) {
if ($channel == 'ORDERID'){
#这里$message为10002
if ($message){
//存储到自己的redis库 这里配置了多连接
$redis2 = Redis::connection('driver_outset_time');
$redis2->set('ORDERID_'.$message,time());#value为时间time()
$redis2->EXPIRE('ORDERID_'.$message,time(), 24*60*60);#设置key过期时间为24小时
$this->xxxxx($message,xxx);#执行其他业务逻辑
}
}
});
}