PHP 原生使用RabbitMQ

一、概述

rabbitmq 是基于amqp协议的,因此了解amqp协议中的一些概念和消息的声明周期,对于理解rabbitmq原理是有很大帮助的。

 

二、配置环境

1、使用docker搭建lnmp 环境 https://hub.docker.com/r/haveyb/lnmp。

2、使用docker搭建rabbitmq 服务 https://www.haveyb.com/article/292

3、安装amqp 扩展 安装该扩展 Linux 源码编译 rabbitmq 扩展 - amqp

 

三、规划

在 lnmp 环境内写消费者和生产者,消费者和生产者使用的都是外部rabbitmq的服务。

存在的问题:

在lnmp容器的环境里,如何使用另一个容器 rabbitmq的服务。

解决方案:

比如这里,我的rabbitmq容器的容器名是rabbit,因此我想看rabbit容器的ip,可以通过命令

 
  1. docker inspect rabbit

可以看到,其他容器想和rabbitmq容器通信,使用172.17.0.3 即可

 

四、代码

1、生产者代码 producer.php

 
  1. <?php
  2. declare(strict_types = 1);
  3.  
  4. try {
  5. // 定义mq连接信息
  6. $amq = new AMQPConnection([
  7. 'host' => '172.17.0.3',
  8. 'port' => 5672,
  9. 'vhost' => '/',
  10. 'login' => 'guest',
  11. 'password' => 'guest'
  12. ]);
  13.  
  14. // 连接mq
  15. $amq->connect();
  16.  
  17. // 通过mq连接创建信道
  18. $channel = new AMQPChannel($amq);
  19.  
  20. // 通过信道创建交换器对象
  21. $exchange = new AMQPExchange($channel);
  22.  
  23. // 设置交换器名称
  24. $exchange->setName('product_exchange');
  25.  
  26. // 设置交换器类型为direct
  27. $exchange->setType(AMQP_EX_TYPE_DIRECT);
  28.  
  29. // 声明交换器
  30. $exchange->declareExchange();
  31.  
  32. $data = [
  33. 'id' => 88,
  34. 'name' => '小脑斧'
  35. ];
  36. $data = json_encode($data);
  37.  
  38. // 发布消息
  39. $exchange->publish($data, 'self_define_routing_key');
  40.  
  41. } catch (\Exception $e) {
  42. var_dump($e->getMessage());
  43. }

 
2、消费者代码 consumer.php

 
  1. <?php
  2. declare(strict_types = 1);
  3.  
  4. try {
  5. // 交换器名称
  6. $exchangeName = 'product_exchange';
  7. // 队列名称
  8. $queueName = 'createProduct';
  9. // RouteKey
  10. $routeKey = 'self_define_routing_key';
  11.  
  12. // 定义mq连接信息
  13. $amq = new AMQPConnection([
  14. 'host' => '172.17.0.3',
  15. 'port' => 5672,
  16. 'vhost' => '/',
  17. 'login' => 'guest',
  18. 'password' => 'guest'
  19. ]);
  20.  
  21. // 连接mq
  22. $amq->connect();
  23.  
  24. // 通过mq连接创建信道
  25. $channel = new AMQPChannel($amq);
  26.  
  27. // 通过信道创建交换器对象
  28. $exchange = new AMQPExchange($channel);
  29.  
  30. // 设置交换器名称
  31. $exchange->setName($exchangeName);
  32.  
  33. // 声明自己监听哪个队列
  34. $queue = new AMQPQueue($channel);
  35.  
  36. $queue->setName($queueName);
  37. $queue->declareQueue();
  38.  
  39. //绑定监听
  40. $queue->bind($exchangeName,$routeKey);
  41. $queue->consume(function ($envelope, $queue){
  42. $data = $envelope->getBody();
  43. var_dump($data);
  44. //回应ack
  45. $queue->ack($envelope->getDeliveryTag());
  46. }); //阻塞监听
  47.  
  48. } catch (\Exception $e) {
  49. var_dump($e->getMessage());
  50. }

 
3、执行结果

先执行 php consumer.php 开始监听消息队列

再执行 php producer.php ,会将消息投递到rabbitmq的queue里,这时你会看到 消费者的窗口已经有输出了,说明消息队列生产并消费成功

然后再执行

 

五、总结

要使用rabbitmq,需要以下几步:

1、对amqp协议有一定了解

2、安装rabbitmq服务

3、安装amqp扩展

4、写生产者和消费者代码

5、执行生产者和消费者代码,看结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值