mac下安装rabbitmq和php+rabbitq

一、首先使用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文件中引入如下:

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

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

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

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

$channel->queue_declare('hello', false, false, false, false);//队列名称hello

$msg = new AMQPMessage('Hello World!');
$channel->basic_publish($msg, '', 'hello');

echo " [x] Sent 'Hello World!'\n";

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

$channel->close();
$connection->close();

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

<?php
/**
 * Created by PhpStorm.
 * User: 漠白
 * Date: 2019-06-23
 * Time: 16:53
 */

require_once 'send.php'; //引入发送类

class demo
{
    /**
     * demo
     * test函数包含众多逻辑,其中b部分负责大量逻辑运算使C端用户不能及时相应。准备把b剥离出来放入队列中,从而做到及时向C端反馈。
     */
    function test()
    {
        //代码功能a部分
        //.....

        //代码功能b部分
        $obj = new BeanStalkSend();//调用生产者
        $obj->SendMessage(100,'test/demo/b/3','second_100');//延时时间、路由、名称

        //代码功能c部分
        //.....

        //代码功能d部分
        //.....
    }

    /**
     * b单独剥离
     * b方法负责大量逻辑运算
     */
    function b($id)
    {
        //逻辑运算
        //.......
    }
}

//实例化调用
$obj = new demo;
$obj->test();

 

  4、消费者接收消息

    注:receive与send基本相同

    4.1 在receive.php文件引入     

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

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

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

    4.3 

$callback = function  ($msg)  {
   //读到消息后的操作
  //.... };
//消耗队列内的消息 $channel-> basic_consume('hello','',false,true,false,false,$ callback);
while(count($channel-> callbacks)){ $channel-> wait(); }

    4.4 关闭频道和链接

$channel->close();
$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)关闭连接。

 

    

 

 

 

  

  

 

posted on 2019-06-24 16:15  漠白  阅读(206)  评论(0编辑  收藏  举报

导航