如果说我们需要一个比较简单的这种机制,我们可以采用redis这个轻量级的订阅机制,我们可以参考redis
的 Publish/Subscribe
机制,得到比较好的问题解决方案
当然,如果是项目比较复杂,可以考虑使用Kafka
, RabbitMQ
之类的消息队列组件
首先简单介绍关于redis
这个机制相关的几个命令
PSUBSCRIBE pattern [pattern ...]
订阅一个或多个符合给定模式的频道。
PUBSUB subcommand [argument [argument ...]]
查看订阅与发布系统状态。
PUBLISH channel message
将信息发送到指定的频道。
PUNSUBSCRIBE [pattern [pattern ...]]
退订所有给定模式的频道。
SUBSCRIBE channel [channel ...]
订阅给定的一个或多个频道的信息。
UNSUBSCRIBE [channel [channel ...]]
指退订给定的频道。
我们是使用Laravel
来实现这个
composer require predis/predis 安装redis组件
使用Laravel创建发送消息文件及接收消息文件
php artisan make:command PublishMsg --command=Pub:Msg
php artisan make:command SubscribeMsg --command=Sub:Msg
在App\Console\Commands\SubscribeMsg.php
中 handle
订阅redis
队列消息
// 启用redis订阅功能 持续监听redis-msg队列是否有消息 如果要消息就会到回调里面被echo
Redis::subscribe(['redis-msg'],function ($message){
echo $message;
});
在App\Console\Commands\PublishMsg.php
中 handle
发送redis
队列消息
try{
// 队列名称 消息
Redis::publish('redis-msg','this a test hahhhhhhhhhhhh');
}catch (\Exception $e){
echo "发送失败";
}
php artisan Sub:Msg 开启消息订阅
php artisan Pub:Msg 开启消息发布
在实际中需要传输数据时,一般会将其序列化为字符串或以json
XML
等格式进行发送
本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。