文章目录

  • 1.生产者代码
  • 2.消费者代码
    • 2.1 消费幂等性代码
    • 2.2 消费者rpc代码
    • 2.3 消费者消费重试
    • 2.4 消费者直接交换机代码
    • 2.5 基础代码
1.生产者代码
<?php
namespace app\controller;use app\BaseController;
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
use PhpAmqpLib\Wire\AMQPTable;
use think\facade\Cache;class RabbitMq extends BaseController
{/*** 直接发送到队列* @return string*/public function send(){//        echo "hello ,mq";die();//队列名称,每个消息都会被投入到1个或者多个队列$queue = "hello_durable_true";//建立连接$connection = new AMQPStreamConnection("localhost", '5672', 'guest', 'guest', '/');//获取信道$channel = $connection->channel();//声明创建队列$channel->queue_declare($queue, false, true, false, false);for ($i = 0; $i < 5; $i++) {sleep(1); //休眠1秒//消息内容$messageBody = "hello,努力,Now time:" . date("Y-m-d H:i:s");//将我们需要的消息标记为持久化$message = new AMQPMessage($messageBody, array("content_type" => "text/plain", "delivery_mode" => AMQPMessage::DELIVERY_MODE_PERSISTENT));//发送消息$channel->basic_publish($message, '', $queue);echo "send Message" . $i . "<br>\n";}//关闭信道$channel->close();//关闭连接$connection->close();return "send success";}/*** 发布订阅*/public function send1(){//交换机名称$exchange = "logs";//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//声明交换机$channel->exchange_declare($exchange, "fanout", false, false, false);for ($i = 0; $i < 5; $i++) {sleep(1);//休眠1秒//消息内容$messageBody = "hello,努力,Now time:" . date("Y-m-d H:i:s");//将我们需要的消息标记为持久化$message = new AMQPMessage($messageBody, array("content_type" => "text/plain","delivery_mode" => AMQPMessage::DELIVERY_MODE_PERSISTENT));//发送消息$channel->basic_publish($message, $exchange);echo "Send exchange message:" . $i . "<br>\n";}//关闭信道$channel->close();//关闭连接$connection->close();return "Send Sueccess";}/*** 直接交换机* @return string*/public function direct(){//        echo "direct";die();//交换机名称$exchange = "direct_logs";//建立连接$connection = new AMQPStreamConnection("127.0.0.1","5672","guest","guest","/");//获取信道$channel = $connection->channel();//声明交换机$channel->exchange_declare($exchange,"direct",false,false,false);//模拟发送error消息内容$messageBody = "error,Now Time:".date("Y-m-d H:i:s");//将我们需要的消息标记为持久化$message = new AMQPMessage($messageBody,array('content_type' => 'text/plain','delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));//绑定info路由$channel->basic_publish($message,$exchange,"error");//模拟发送warning消息内容$messageBody = "warning, Now Time:".date("h:i:s");//将我们需要的消息标记为持久化 - 通过设置AMQPMessage的参数delivery_mode = AMQPMessage::DELIVERY_MODE_PERSISTENT$message = new AMQPMessage($messageBody, array('content_type' => 'text/plain','delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));//绑定warning路由$channel->basic_publish($message, $exchange, "warning");//关闭信道$channel->close();//关闭连接$connection->close();return 'Send Success';}/*** 远程调用*/public function rpc(){$connection = new AMQPStreamConnection("localhost","5672","guest","guest","/");$channel = $connection->channel();//申明回调队列list($callback_queue,,) = $channel->queue_declare("callback_queue",false,false,true,false);//RPC客户端请求参数$corr_id = uniqid();$msg = new  AMQPMessage("rpc client send message",array("correlation_id"=>$corr_id,'reply_to' =>$callback_queue));//发送RPC请求$channel->basic_publish($msg,'','rpc_queue');//在rpc服务端返回的内容$response = null;//等待RPC回调$channel->basic_consume($callback_queue,'',false,false,false,false,function ($reply)use ($corr_id,&$response){if ($reply->get("correlation_id") == $corr_id){$response = $reply->body;}//确认消息处理完成$reply->delivery_info['channel']->basic_ack($reply->delivery_info['delivery_tag']);});while (!$response){$channel->wait();}var_dump($response);$channel->close();$connection->close();}/*** 延迟队列  死信队列* @return string*/public function delay(){//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//创建DLX及死信队列$channel->exchange_declare("dlx_exchange", "direct", false, false, false);$channel->queue_declare("dlx_queue",false,true,false,false);$channel->queue_bind("dlx_queue","dlx_exchange","dlx_routing_key");//创建延迟队列$channel->exchange_declare("delay_exchange",'direct',false,false,false);$args = new AMQPTable();//消息过期方式:设置queue.normal队列中的消息,5s后过期$args->set('x-message-ttl',5000);//设置队列最大长度方式:x-max-length$args->set("x-max-length",1);$args->set('x-dead-letter-exchange','dlx_exchange');$args->set('x-dead-letter-routing-key',"dlx_routing_key");$channel->queue_declare("delay_queue",false,true,false,false,false,$args);$channel->queue_bind("delay_queue","delay_exchange","delay_routing_key");//模拟发送消息内容$messageBody = "该消息将在5s后发送到延迟队列(".date("h:i:s").")";//将我们需要的消息标记为持久化 - 通过设置AMQPMessage的参数delivery_mode = AMQPMessage::DELIVERY_MODE_PERSISTENT$message = new AMQPMessage($messageBody, array('content_type' => 'text/plain','delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));//绑定delay.routingKey路由$channel->basic_publish($message, "delay_exchange", "delay_routing_key");//关闭信道$channel->close();//关闭连接$connection->close();return 'Send Success';}/*** 重试队列*/public function retry(){//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//创建DLX及死信队列$channel->exchange_declare("dlx_exchange", "direct", false, false, false);$channel->queue_declare("dlx_queue", false, true, false, false);$channel->queue_bind("dlx_queue", "dlx_exchange", "dlx_routing_key");//创建延迟队列$channel->exchange_declare("delay_exchange", "direct", false, false, false);$args = new AMQPTable();// 消息过期方式:设置 queue.normal 队列中的消息5s之后过期$args->set('x-message-ttl', 5000);// 设置队列最大长度方式: x-max-length
//        $args->set('x-max-length', 100);$args->set('x-dead-letter-exchange', 'dlx_exchange');$args->set('x-dead-letter-routing-key', 'dlx_routing_key');$channel->queue_declare("delay_queue", false, true, false, false, false, $args);$channel->queue_bind("delay_queue", "delay_exchange", "delay_routing_key");//模拟发送消息内容$messageBody = "该消息将在5s后发送到延迟队列(".date("h:i:s").")";//将我们需要的消息标记为持久化 - 通过设置AMQPMessage的参数delivery_mode = AMQPMessage::DELIVERY_MODE_PERSISTENT$message = new AMQPMessage($messageBody, array('content_type' => 'text/plain','delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));//设置重试次数,默认0$headers = new AMQPTable(["retry_nums" => 0]);$message->set('application_headers', $headers);//绑定delay.routingKey路由$channel->basic_publish($message, "delay_exchange", "delay_routing_key");//关闭信道$channel->close();//关闭连接$connection->close();return 'Send Success';}/*** 消费幂等* @return string*/public function idempotent(){//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//创建DLX及死信队列$channel->exchange_declare("dlx_exchange1", "direct", false, false, false);$channel->queue_declare("dlx_queue1", false, true, false, false);$channel->queue_bind("dlx_queue1", "dlx_exchange1", "dlx_routing_key1");//创建延迟队列$channel->exchange_declare("delay_exchange1", "direct", false, false, false);$args = new AMQPTable();// 消息过期方式:设置 queue.normal 队列中的消息5s之后过期$args->set('x-message-ttl', 5000);// 设置队列最大长度方式: x-max-length//$args->set('x-max-length', 1);$args->set('x-dead-letter-exchange', 'dlx_exchange1');$args->set('x-dead-letter-routing-key', 'dlx_routing_key1');$channel->queue_declare("delay_queue1", false, true, false, false, false, $args);$channel->queue_bind("delay_queue1", "delay_exchange1", "delay_routing_key1");//模拟发送消息内容$messageBody = "重复消息发送(".date("h:i:s").")";//将我们需要的消息标记为持久化 - 通过设置AMQPMessage的参数delivery_mode = AMQPMessage::DELIVERY_MODE_PERSISTENT$message = new AMQPMessage($messageBody, array('content_type' => 'text/plain','delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT));//设置消息ID,防止重复消费$corr_id = uniqid();$headers = new AMQPTable(["correlation_id" => $corr_id]);$message->set('application_headers', $headers);Cache::set($corr_id, $corr_id, 3600);//绑定delay.routingKey路由$channel->basic_publish($message, "delay_exchange1", "delay_routing_key1");//模拟发送重复消息$channel->basic_publish($message, "delay_exchange1", "delay_routing_key1");//关闭信道$channel->close();//关闭连接$connection->close();return 'Send Success';}
}
2.消费者代码
2.1 消费幂等性代码
<?phpnamespace app\command;use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Wire\AMQPTable;
use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\input\Option;
use think\console\Output;
use think\facade\Cache;class Idempotentnd extends Command
{protected function configure(){// 指令配置$this->setName('idempotent')->setDescription('the idempotent command');        }protected function execute(Input $input, Output $output){//交换机名$exchange = "dlx_exchange1";//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//声明交换机$channel->exchange_declare($exchange, 'direct', false, false, false);$channel->queue_declare("dlx_queue1", false, true, false, false);$channel->queue_bind("dlx_queue1", $exchange, "dlx_routing_key1");//创建重试队列$channel->exchange_declare("delay_exchange1", "direct", false, false, false);$args = new AMQPTable();// 消息过期方式:设置 queue.normal 队列中的消息5s之后过期$args->set('x-message-ttl', 5000);// 设置队列最大长度方式: x-max-length //$args->set('x-max-length', 1);$args->set('x-dead-letter-exchange', 'dlx_exchange1');$args->set('x-dead-letter-routing-key', 'dlx_routing_key1');$channel->queue_declare("delay_queue1", false, true, false, false, false, $args);$channel->queue_bind("delay_queue1", "delay_exchange1", "delay_routing_key1");//消息消费$channel->basic_consume("dlx_queue1", '', false, false, false, false, function ($msg) use ($output, $channel)  {$msg_headers = $msg->get('application_headers')->getNativeData();$corr_id = $msg_headers['correlation_id'];//判断是否已经消费过if(Cache::get($corr_id) === null){$body = "该消息已消费,不再消费";$output->writeln(date("h:i:s") . $body .  PHP_EOL);//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);return;}$body =  $msg->body;$output->writeln("生产者发送的消息:".date("h:i:s") . " Received " . $body .  PHP_EOL);//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);Cache::delete($corr_id);});while (count($channel->callbacks)) {$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}
}
2.2 消费者rpc代码
<?php
declare (strict_types = 1);namespace app\command;use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\input\Option;
use think\console\Output;class RpcCommand extends Command
{protected function configure(){// 指令配置$this->setName('rpc')->setDescription('the rpc command');        }protected function execute1(Input $input, Output $output){$queue = "rpc_queue";$connection = new AMQPStreamConnection("localhost","5672","guest","guest","/");$channel = $connection->channel();$channel->queue_declare($queue,false,false,true,false);//公平调度$channel->basic_qos(null,1,null);$channel->basic_consume($queue,'',false,false,false,false,function ($msg) use($output){//接受rpc客户端接收的消息$output->writeln("Received:".$msg->body.PHP_EOL);//执行方法,回调队列$reply = new AMQPMessage("rpc server replay message",array("correlation_id"=>$msg->get('correlation_id')));$msg->delivery_info['channel']->basic_publish($reply,'',$msg->get('reply_to'));//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);});while (count($channel->callbacks)){$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}protected function execute(Input $input, Output $output){//队列名$queue = "rpc_queue";//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//声明创建队列$channel->queue_declare($queue, false, false, true, false);//公平调度$channel->basic_qos(null, 1, null);//消息消费$channel->basic_consume($queue, '', false, false, false, false, function ($msg) use ($output)  {//接收到RPC客户端收到的消息$output->writeln(" Received " . $msg->body .  PHP_EOL);//执行方法,回调队列$reply = new AMQPMessage("rpc server replay  message",array('correlation_id' => $msg->get('correlation_id')));$msg->delivery_info['channel']->basic_publish($reply, '', $msg->get('reply_to'));//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);});while (count($channel->callbacks)) {$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}
}
2.3 消费者消费重试
<?php
declare (strict_types = 1);namespace app\command;use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Wire\AMQPTable;
use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\input\Option;
use think\console\Output;class RetryCommand extends Command
{protected function configure(){// 指令配置$this->setName('retry')->setDescription('the retry command');        }protected function execute(Input $input, Output $output){//交换机名$exchange = "dlx_exchange";//建立连接$connection = new AMQPStreamConnection("localhost", "5672", "guest", "guest", "/");//获取信道$channel = $connection->channel();//声明交换机$channel->exchange_declare($exchange, 'direct', false, false, false);$channel->queue_declare("dlx_queue", false, true, false, false);$channel->queue_bind("dlx_queue", $exchange, "dlx_routing_key");//创建重试队列$channel->exchange_declare("delay_exchange", "direct", false, false, false);//消息消费$channel->basic_consume("dlx_queue", '', false, false, false, false, function ($msg)use($output,$channel){$body =  $msg->body;$output->writeln(date("h:i:s") . " Received " . $body .  PHP_EOL);//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);$msg_headers = $msg->get('application_headers')->getNativeData();//重试次数超过3次,则入库告警if (intval($msg_headers['retry_nums']) > 3) {$body = "重试次数超过3次,则入库告警";$output->writeln(date("h:i:s") . " Error " . $body .  PHP_EOL);} else {//重试次数加1$headers = new AMQPTable(["retry_nums" => intval($msg_headers['retry_nums']) + 1]);$msg->set('application_headers', $headers);//放回重试队列$channel->basic_publish($msg, "delay_exchange", "delay_routing_key");}});while (count($channel->callbacks)) {$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}
}
2.4 消费者直接交换机代码
<?php
namespace app\command;use PhpAmqpLib\Connection\AMQPStreamConnection;
use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\input\Option;
use think\console\Output;class Direct1 extends Command
{protected function configure(){// 指令配置$this->setName('directRabbitMQ1')->setDescription('the directRabbitMQ1 command');        }protected function execute(Input $input, Output $output){//交换机名$exchange = "direct_logs";//建立连接$connection = new AMQPStreamConnection('127.0.0.1', 5672, 'guest', 'guest', '/');//获取信道$channel = $connection->channel();//声明交换机$channel->exchange_declare($exchange, 'direct', false, false, false);//声明创建队列//队列名称为空时,会生成一个随机名称队列list($queue, ,) = $channel->queue_declare('', false, false, true, false);//绑定交换机与队列,并指定路由info$channel->queue_bind($queue, $exchange, 'info');//绑定交换机与队列,并指定路由error$channel->queue_bind($queue, $exchange, 'error');//绑定交换机与队列,并指定路由warning$channel->queue_bind($queue, $exchange, 'warning');//消息消费$channel->basic_consume($queue, '', false, false, false, false, function ($msg) use ($output)  {//模拟耗时sleep(3);$output->writeln(" Received " . $msg->body .  PHP_EOL);//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);});while (count($channel->callbacks)) {$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}
}
2.5 基础代码
<?php
namespace app\command;use PhpAmqpLib\Connection\AMQPStreamConnection;
use think\console\Command;
use think\console\Input;
use think\console\Output;class Rabbitmq extends Command
{public function configure(){//指令配置$this->setName("mq")->setDescription("the mq command");}protected function execute(Input $input, Output $output){//队列名$queue = "hello_durable_true";//建立连接$connection = new AMQPStreamConnection("localhost","5672","guest","guest");//获取信道$channel = $connection->channel();//声明创建队列//生产者和消费者对queue的声明函数里,这个durable必须保持一致。否则报错PRECONDITION_FAILED - inequivalent arg 'durable' for queue 'hello' in vhost '/': received 'true' but current is 'false'$channel->queue_declare($queue,false,true,false,false);//消息消费$channel->basic_consume($queue,'',false,false,false,false,function ($msg) use ($output){sleep(3);//输出到终端$output->writeln("Received".$msg->body.PHP_EOL);//确认消息处理完成$msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']);});while (count($channel->callbacks)){$channel->wait();}//关闭信道$channel->close();//关闭连接$connection->close();}
}

rabbitmq代码相关推荐

  1. rabbitMQ教程 spring整合rabbitMQ代码实例

    转载自 https://www.cnblogs.com/tohxyblog/p/7256554.html 一.开启rabbitMQ服务,导入MQ jar包和gson jar包(MQ默认的是jackso ...

  2. SpringBoot RabbitMQ 延迟队列代码实现

    场景 用户下单后,如果30min未支付,则删除该订单,这时候就要可以用延迟队列 准备 利用rabbitmq_delayed_message_exchange插件: 首先下载该插件:https://ww ...

  3. Spring Boot2.x-15 整合RabbitMQ 及RabbitMQ的基本使用

    文章目录 概述 在Docker CE中安装RabbitMQ 依赖 配置 基本使用 手工创建队列,发送消息到指定的队列 自动创建队列,发送消息到指定的队列 自动创建队列,Exchange和队列绑定 自动 ...

  4. [c#]RabbitMQ的简单使用

    摘要 Message Queue消息队列,简称MQ,是一种应用程序对应用程序的通信方法,应用程序通过读写出入队列的消息来通信,而无需专用连接来链接它们.消息传递指的是程序之间通过在消息中发送数据进行通 ...

  5. RabbitMQ,RabbitMQ 的工作模式,Spring 整合 RabbitMQ,Springboot 整合RabbitMQ

    什么是RabbitMQ 1.1 MQ概述 MQ全称 Message Queue(消息队列),是在消息的传输过程中保存消息的容器.多用于分布式系统之间进行通信. ⚫ MQ,消息队列,存储消息的中间件 ⚫ ...

  6. 【原创】Windows下使用 Eclipse 管理 RabbitMQ 源码之问题解决

    2019独角兽企业重金招聘Python工程师标准>>> 使用 Eclipse + Erlide 来管理 Erlang 代码是一种常见方式.本文简要说明下,本人在 Windows 下管 ...

  7. RabbitMQ管理(4)——应用管理

    欢迎支持笔者新作:<深入理解Kafka:核心设计与实践原理>和<RabbitMQ实战指南>,同时欢迎关注笔者的微信公众号:朱小厮的博客. 欢迎跳转到本文的原文链接:https: ...

  8. scala akka_使用Scala,Play和Akka连接到RabbitMQ(AMQP)

    scala akka 在本文中,我们将研究如何从Scala连接到RabbitMQ,以便可以从应用程序中支持AMQP协议. 在此示例中,我将使用Play Framework 2.0作为容器(有关更多信息 ...

  9. 使用Scala,Play和Akka连接到RabbitMQ(AMQP)

    在本文中,我们将研究如何从Scala连接到RabbitMQ,以便可以从应用程序中支持AMQP协议. 在此示例中,我将使用Play Framework 2.0作为容器(有关更多信息,请参阅我在该主题上的 ...

最新文章

  1. gocron - 定时任务管理系统
  2. WPF 3D 学习 - 3D材质初步
  3. SEH(结构化异常处理)
  4. 开发中的问题——环境相关
  5. java代码鸟飞_180行原生js代码实现简易版飞行的小鸟游戏
  6. sql查询初学者指南_面向初学者SQL Server查询执行计划–聚集索引运算符
  7. Linux 高阶命令进阶(一)
  8. IDEA给项目添加lib/jar
  9. CSS 绘制三角形原理演示(动画)
  10. 互联网赚钱:一个抖音小项目,分析下,人人都能做
  11. BuBu笔记——Mybatis入门(秃头BUBu的超详细备注,一定要看哦)
  12. MATLAB中subs函数
  13. 企业宣传软文怎么写?手把手教大家撰写企业宣传软文
  14. oppo文件管理android在哪里,OPPO手机中缓存视频文件路径在哪里查看?怎么查看?
  15. 解决:win10下teamviewer检测为商业用途
  16. 阿里云学生成长计划续费资格考试
  17. 韩顺平学Java之九九乘法表
  18. Android特效专辑(一)——水波纹过渡特效(首页)
  19. C#制作简易屏保(转)
  20. 如何进行服务器的选购

热门文章

  1. php篮球比赛,篮球数据API接口 - 【篮球比赛动画直播变化数据】API调用示例代码...
  2. redis php操作日志,php-redis笔记
  3. 商城客户细分数据(kaggle)
  4. 数据分析案例(贷款风险预测)
  5. 深圳内推 | ​IDEA数字经济研究院招聘NLP算法工程师/算法实习生
  6. 输入梯度惩罚与参数梯度惩罚的一个不等式
  7. 24张IT工程师技能图谱,这些你都会吗?
  8. NLP中的Mask全解
  9. 基于深度学习的多目标跟踪算法(上):端到端的数据关联
  10. AAAI 2019 Oral | 让TA说你想听的—基于音/视频特征解离的讲述者人脸生成