一、首先使用brew安装rabbitmq

  brew install rabbitmq

  安装完成,终端会出现如下内容,如图:

  启动RabbitMQ

    前台运行rabbitmq-server

    后台运行brew service start rabbitmq

  以上为安装rabbitmq,接下来我们来演示如何使用rabbitmq

二、PHP+RabbitMq

  前文中我们已经介绍了rabbitmq的基本定义和使用场景,接下来我们学习如何简单的使用。
  使用时参照rabbitmq官方文档:https://www.rabbitmq.com/

  1、使用composer安装所需的扩展

    composer require php-amqplib/php-amqplib

  

  2、创建消息生产者(发送者)send.php 和 消费者(接受者)receive.php两个文件

    send.php      生产者生产消息

    receive.php   消费者接收消息

  3、生产者发送消息

    3.1 在send.php文件中引入如下:

  1. require_once __DIR__ . '/vendor/autoload.php';
  2. use PhpAmqpLib\Connection\AMQPStreamConnection;
  3. use PhpAmqpLib\Message\AMQPMessage;

    3.2 创建服务器链接,我们链接的是本地服务器因此是本地连接localhost    

  1. $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
  2. $channel = $connection->channel();

    3.3 接下来我们要创建一个频道,我们想要发送消息必须声明一个队列可供我们发送,然后我们向队列中发送消息

  1. $channel->queue_declare('hello', false, false, false, false);//队列名称hello
  2.  
  3. $msg = new AMQPMessage('Hello World!');
  4. $channel->basic_publish($msg, '', 'hello');
  5.  
  6. echo " [x] Sent 'Hello World!'\n";

    3.4 最后我们关闭频道和链接

  1. $channel->close();
  2. $connection->close();

    3.5 通常我们会把发送send.php进行封装后调用(根据业务需求对类进行封装),如何调用附上我写的demo

  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: 漠白
  5. * Date: 2019-06-23
  6. * Time: 16:53
  7. */
  8.  
  9. require_once 'send.php'; //引入发送类
  10.  
  11. class demo
  12. {
  13. /**
  14. * demo
  15. * test函数包含众多逻辑,其中b部分负责大量逻辑运算使C端用户不能及时相应。准备把b剥离出来放入队列中,从而做到及时向C端反馈。
  16. */
  17. function test()
  18. {
  19. //代码功能a部分
  20. //.....
  21.  
  22. //代码功能b部分
  23. $obj = new BeanStalkSend();//调用生产者
  24. $obj->SendMessage(100,'test/demo/b/3','second_100');//延时时间、路由、名称
  25.  
  26. //代码功能c部分
  27. //.....
  28.  
  29. //代码功能d部分
  30. //.....
  31. }
  32.  
  33. /**
  34. * b单独剥离
  35. * b方法负责大量逻辑运算
  36. */
  37. function b($id)
  38. {
  39. //逻辑运算
  40. //.......
  41. }
  42. }
  43.  
  44. //实例化调用
  45. $obj = new demo;
  46. $obj->test();

  4、消费者接收消息

    注:receive与send基本相同

    4.1 在receive.php文件引入     

  1. require_once __DIR__ . '/vendor/autoload.php';
  2. use PhpAmqpLib\Connection\AMQPStreamConnection;

    4.2 打开一个链接和通道,并声明要消耗的队列,注意:要与发送的队列名称匹配      

  1. //创建链接
    $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
  2. $channel = $connection->channel();
  3.  
  4. $channel->queue_declare('hello', false, false, false, false);//队列名称hello
  5.  
  6. echo " [*] Waiting for messages. To exit press CTRL+C\n";

    4.3

  1. $callback = function $msg {
  2. //读到消息后的操作
      //....
  3. };

  4. //消耗队列内的消息
  5. $channel-> basic_consume'hello'''falsetruefalsefalse$ callback);
    whilecount$channel-> callbacks)){
  6. $channel-> wait();
  7. }

    4.4 关闭频道和链接

  1. $channel->close();
  2. $connection->close();

总结:

生产者生产过程:
  (1)生产者连接到 RabbitMQ Broker 建立一个连接( Connection) ,开启 个信道 (Channel)
  (2) 生产者声明一个交换器 ,并设置相关属性,比如交换机类型、是否持久化等
  (3)生产者声明 个队列井设置相关属性,比如是否排他、是否持久化、是否自动删除等 
  (4)生产者通过路由键将交换器和队列绑定起来。 
  (5)生产者发送消息至 RabbitMQ Broker ,其中包含路由键、交换器等信息。 
  (6) 相应的交换器根据接收到的路由键查找相匹配的队列 如果找到 ,则将从生产者发送过来的消息存入相应的队列中。 
  (7) 如果没有找到 ,则根据生产者配置的属性选择丢弃还是回退给生产者
  (8) 关闭信道。
  (9) 关闭连接。

消费者接收消息的过程: 
  (1)消费者连接到 RabbitMQ Broker ,建立一个连接(Connection ,开启 个信道(Channel)
  (2) 消费者向 RabbitMQ Broker 请求消费相应队列中的消息,可能会设置相应的回调函数, 以及做 些准备工作。
  (3)等待 RabbitMQ Broker 回应并投递相应队列中的消息, 消费者接收消息。
  (4) 消费者确认 ack) 接收到的消息 
  (5) RabbitMQ 从队列中删除相应己经被确认的消息
  (6) 关闭信道。
  (7)关闭连接。

    

  

  

mac下安装rabbitmq和php+rabbitq的更多相关文章

  1. mac下安装rabbitmq

    使用homebrew安装rabbitmq,命令如下: brew install rabbitmq 安装的位置如下/usr/local/Cellar/rabbitmq/3.7.18 进入到sbin目录下 ...

  2. MAC 下安装RabbitMQ

    1.使用brew来安装 RabbitMQ(地址:http://www.rabbitmq.com/install-standalone-mac.html ) 2.安装目录 /usr/local/Cell ...

  3. mac下安装 rabbitMq

    1.安装HomeBrew,如果已经安装这一步跳过. 2.用brew install rabbitmq指令即可进行rabbitmq服务的自动安装. 3.安装完成之后会出现一下提示:   rabbit安装 ...

  4. Mac 下安装Jenkins

    Mac 下安装Jenkins 开始 Jenkins是一个基于Java开发的一种持续集成工具,用于建工持续重复的工作,功能包括: 持续的软件版本发布/测试项目 监控外部调用执行的工作. 近期打算搭建自动 ...

  5. MAC下安装与配置MySQL

    MAC下安装与配置MySQL   MAC下安装与配置MySQL 一 下载MySQL 访问MySQL的官网http://www.mysql.com/downloads/ 然后在页面中会看到“MySQL ...

  6. Mac下安装UPnP Inspector

    由于工作中需要用到UPnP Inspector这个工具,而这个工具在windows下安装非常简单,在Mac下安装却很麻烦,在此记录安装流程. 这个工具依赖于两个其他的库:Coherence(一个DLN ...

  7. Mac下安装Wireshark,双击闪退

     Mac OS X上使用Wireshark抓包(http://blog.csdn.net/phunxm/article/details/38590561) Mac下安装Wireshark /Appli ...

  8. Mac下安装zshell

    Mac 下安装zshell 什么是shell 大多数命令行用户接触最多的是Bash,因为Bash是各个版本操作系统(Linux&Mac)的默认shell. 查看当前使用的shell $ ech ...

  9. 【高可用HA】Apache (1) —— Mac下安装Apache Httpd到自定义路径(非/etc/apache2)

    Mac下安装Apache Httpd httpd版本: httpd-2.4.17 参考来源: Tomcat Clustering - A Step By Step Guide Apache HTTP ...

随机推荐

  1. nginx经验分享

    如果我们在使用启动nginx时,遇到这样的提示: nginx: [alert] could not open error log file: open() "/usr/local/var/l ...

  2. Codeforce-Ozon Tech Challenge 2020-B. Kuroni and Simple Strings(贪心)

    B. Kuroni and Simple Strings time limit per test1 second memory limit per test256 megabytes inputsta ...

  3. Sunday算法:字符串匹配算法进阶

    背景 我们第一次接触字符串匹配,想到的肯定是直接用2个循环来遍历,这样代码虽然简单,但时间复杂度却是\(Ω(m*n)\),也就是达到了字符串匹配效率的下限.于是后来人经过研究,构造出了著名的KMP算法 ...

  4. VUE简单整理

    在用 Vue.js 构建大型应用时推荐使用 NPM 安装: # 最新稳定版 $ cnpm install vue 命令行工具 Vue.js 提供一个官方命令行工具,可用于快速搭建大型单页应用. # 全 ...

  5. 《Docker从入门到跑路》之存储卷介绍

    默认情况下,容器会随着用户删除而消失,包括容器里面的数据.如果我们要对容器里面的数据进行长久保存,就不得不引用存储卷的概念. 在容器中管理数据持久化主要有两种方式:1.数据卷(data volumes ...

  6. rabbitmq添加自启动 centos7环境

    1.编辑一个启动脚本 [root@xxx ~]# vim /usr/local/rabbitmq/sbin/start_rabbitmq.sh 内容如下(根据自己的实际位置做替换即可) #!/bin/ ...

  7. 现代企业要求上什么样的MES(四)

    一个制造企业要想盈利,在生产方面要做的无非是提高资源利用效率和缩短生产通过时间(生产周期),而实现这俩步骤需要生产状况的在线透明及避免薄弱环节的分析数据,由此达到改善生产状态的目的.在erp系统中,通 ...

  8. SpringBoot:整合SpringSecurity

    目录 SpringSecurity(安全) 搭建环境 使用 用户认证和授权 注销及权限控制 记住我及登录页面定制 SpringBoot 整合 SpringSecurity: 用户认证和授权.注销及权限 ...

  9. HMM-前向后向算法理解与实现(python)

    目录 基本要素 HMM三大问题 概率计算问题 前向算法 后向算法 前向-后向算法 基本要素 状态 \(N\)个 状态序列 \(S = s_1,s_2,...\) 观测序列 \(O=O_1,O_2,.. ...

  10. [hdu4576]dp

    题意:1-n围成1圈,从1出发,第i次走a[i]步,问走m次后出现在[L,R]的概率L<=R. 思路:明显的DP,把编号变成0~n-1,令dp[i][j]表示走完i步之前停在了j上,则有dp[i ...