RabbitMQ-消息队列延迟队列二

1、安装rabbitmq

怎么安装rabbitmq请查看之前课程,如果已经安装,请略过此步。

2、创建vendor文件夹或是直接采用PHP框架

复制代码
mkdir vendor

3、进入文件

复制代码
cd vendor

4、安装php扩展

复制代码
composer require php-amqplib/php-amqplib

5、进入上级创建delay文件夹

复制代码
cd ../
mkdir delay

6、进入delay文件并创建生产者php

复制代码
cd delay
touch delay_pub.php

7、输入delay生产者内容

复制代码
<?php

require_once  '../vendor/autoload.php';

use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
use PhpAmqpLib\Wire\AMQPTable;

$v_host = 'order';

$exc_name ='delay_exc_pay';
$routing_key = 'delay_route_pay';
$queue_name = 'delay_queue_pay';
$ttl = 20000;
$connection = new AMQPStreamConnection('localhost',5672,'wangyulong','wangyulong',$v_host);

$channel = $connection->channel();

$channel->exchange_declare($exc_name,'x-delayed-message',false,true,false);

$args = new AMQPTable(['x-delayed-type'=>'direct']);

$channel->queue_declare($queue_name,false,true,false,false,false,$args);

$channel->queue_bind($queue_name,$exc_name,$routing_key);
$data = 'this is dead message';

$arr = ['delivery_mode'=>AMQPMEssage::DELIVERY_MODE_PERSISTENT,'application_headers'=>new AMQPTable(['x-delay'=>$ttl])];

$msg = new AMQPMessage($data,$arr);

$channel->basic_publish($msg,$exc_name,$routing_key);

$channel->close();

$connection->close();

8、创建消费者php

复制代码
touch delay_worker.php

9、输入delay消费者内容

复制代码
<?php

require_once  '../vendor/autoload.php';

use PhpAmqpLib\Connection\AMQPStreamConnection;

$v_host ='order';

$exc_name ='delay_exc_pay';
$routing_key = 'delay_route_pay';
$queue_name = 'delay_queue_pay';

$connection = new AMQPStreamConnection('localhost',5672,'wangyulong','wangyulong',$v_host);

$channel = $connection->channel();

$channel->exchange_declare($exc_name,'x-delayed-message',false,true,false);


$channel->queue_bind($queue_name,$exc_name,$routing_key);

$callback = function($msg){
	echo 'received ' ,$msg->body,"\n";
	$msg->ack();
};

$channel->basic_qos(null,1,null);

$channel->basic_consume($queue_name,'',false,false,false,false,$callback);

while($channel->is_open()){
	$channel->wait();
}

$channel->close();

$connection->close();

10、执行消费者

复制代码
php delay_worker.php

11、执行生产者

复制代码
php delay_pub.php
此时你会发现只有delay消费者并没有数据,而是退后2秒才有数据。这就是rabbitmq delay延迟队列工作模式硬实力
延迟队列需要提前添加交换机
相关推荐
Wang's Blog1 小时前
Kafka: 分布式配置管理的核心挑战
分布式·kafka
TG:@yunlaoda360 云老大2 小时前
如何在华为云国际站代理商控制台进行SFS Turbo的基础状态核查?
大数据·服务器·华为云·php
回家路上绕了弯2 小时前
分布式事务TCC详解:高并发场景下的柔性事务最优解?
分布式·后端
是阿威啊2 小时前
【第一站】本地虚拟机部署Hadoop分布式集群
大数据·linux·hadoop·分布式
韩立学长4 小时前
【开题答辩实录分享】以《学生心理预防监控信息系统的设计与实现开题报告》为例进行选题答辩实录分享
mysql·php
川215 小时前
ZooKeeper配置+失误
linux·分布式·zookeeper
zzoood5 小时前
【PHP】富文本编辑器图片自动追加域名
开发语言·php
catchadmin5 小时前
PHP 初学者指南 基础结构与常见错误
php
风途知识百科5 小时前
并网/分布式光伏气象站
人工智能·分布式
云和数据.ChenGuang5 小时前
运维工程师技术教程之Pull Requests(PR)
运维·分布式·git·数据库运维工程师·运维教程