RabbitMQ-消息队列之work使用

1、安装rabbitmq

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

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

复制代码
mkdir vendor

3、进入文件

复制代码
cd vendor

4、安装php扩展

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

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

复制代码
cd ../
mkdir worker

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

复制代码
cd worker
touch pro.php

7、输入worker生产者内容

复制代码
<?php

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


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

$v_host = 'order';

$queue_name = 'task_queue';

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

$channel = $connection->channel();


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


for($i=1;$i<=10;$i++){

	$data = 'this is '.$i.' message';


	$msg = new AMQPMessage($data,['delivery_mode'=>AMQPMessage::DELIVERY_MODE_PERSISTENT]);


	$channel->basic_publish($msg,'',$queue_name);

}

$channel->close();

$connection->close();

8、创建消费者php

复制代码
touch worker.php

9、输入worker消费者内容

复制代码
<?php

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


use PhpAmqpLib\Connection\AMQPStreamConnection;

$v_host ='order';
$queue_name = 'task_queue';

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

$channel = $connection->channel();

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


$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 pro.php

11、执行消费者

复制代码
php worker.php
此时,10条数据很快就执行完毕。如果你再复制一份消费者2出来,与消费者1同时执行,这个时候你重新执行以下生产者,你会发现,消费者1的结果展示是1 3 5 7 9,消费者2的结果展示是 2 4 6 8 10。这就是rabbitmq消费者最高的硬实力
相关推荐
brzhang11 分钟前
代码即图表:dbdiagram.io让数据库建模变得简单高效
前端·后端·架构
Jamesvalley15 分钟前
【Django】新增字段后兼容旧接口 This field is required
后端·python·django
欧先生^_^21 分钟前
Spark 的一些典型应用场景及具体示例
大数据·分布式·spark
秋野酱27 分钟前
基于 Spring Boot 的银行柜台管理系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
JAVA学习通42 分钟前
JAVA多线程(8.0)
java·开发语言
Luck_ff08101 小时前
【Python爬虫详解】第四篇:使用解析库提取网页数据——BeautifuSoup
开发语言·爬虫·python
学渣676561 小时前
什么时候使用Python 虚拟环境(venv)而不用conda
开发语言·python·conda
獨枭1 小时前
Spring Boot 连接 Microsoft SQL Server 实现登录验证
spring boot·后端·microsoft
想睡hhh1 小时前
c++STL——stack、queue、priority_queue的模拟实现
开发语言·c++·stl
陶然同学1 小时前
RabbitMQ全栈实践手册:从零搭建消息中间件到SpringAMQP高阶玩法
java·分布式·学习·rabbitmq·mq