RabbitMQ+PHP演示實例二

接下來我們用 php 連接 rabbitmq 玩一玩。
還沒有安裝 rabbitmq ,請參考 Rabbitmq 安裝
還沒有安裝 PHP 的 AMQP 擴展,參考 PHP AMQP 擴展安裝

一些概念

Rabbitmq 是一個功能很強大消息隊列系統,使用起來可能不像某些 push 、pop 類型的隊列簡單(比如 redis 的list),Rabbitmq 支持消息的訂閱發佈模式,方便大型系統各個服務組件之間解耦和通信。我們首先要了解一些基本概念

Vhost: 可以先不深究,固定爲 /
Connection:即連接, 與你日常理解的連接沒有什麼不同,比如 redis的連接,mysql的連接
Channel:即通道, 可以理解爲一個連接中的子通道,想象一條高速公路,可能是 4車道的,也可能是 8 車道的,這些車道就是 Channel。

Exchange : 交換機,如果你知道交換機設備的話,它的原理跟交換機是基本一樣的。
routingkey : 用來綁定交換機和隊列的一個字符串。發送消息時需要指定 routingKey, 綁定了此 routingKey的隊列將接收到此消息。
queue隊列: 消息經過交換機,最終發送到隊列中。

發佈消息

<?php
$conn = [
    // Rabbitmq 服務地址
    'host' => '127.0.0.1',
    // Rabbitmq 服務端口
    'port' => '5672',
    // Rabbitmq 帳號
    'login' => 'guest',
    // Rabbitmq 密碼
    'password' => 'guest',
    'vhost'=>'/'
];

//創建連接和channel
$conn = new AMQPConnection($conn);
if(!$conn->connect()) {
    die("Cannot connect to the broker!\n");
}
$channel = new AMQPChannel($conn);

// 用來綁定交換機和隊列
$routingKey = 'key_1';

$ex = new AMQPExchange($channel);
//  交換機名稱
$exchangeName = 'ex1';
$ex->setName($exchangeName);

// 設置交換機類型
$ex->setType(AMQP_EX_TYPE_DIRECT);
// 設置交換機是否持久化消息
$ex->setFlags(AMQP_DURABLE);
$ex->declare();

for($i=0; $i<5; ++$i){
    echo "Send Message:".$ex->publish(date('H:i:s')."用戶".$i."註冊" , $routingKey )."\n";
}

以上代碼保存爲 send.php

消費消息

<?php
$conn = [
    // Rabbitmq 服務地址
    'host' => '127.0.0.1',
    // Rabbitmq 服務端口
    'port' => '5672',
    // Rabbitmq 帳號
    'login' => 'guest',
    // Rabbitmq 密碼
    'password' => 'guest',
    'vhost'=>'/'
];


//創建連接和channel
$conn = new AMQPConnection($conn);
if(!$conn->connect()) {
    die("Cannot connect to the broker!\n");
}
$channel = new AMQPChannel($conn);
$exchangeName = 'ex1';

//創建交換機
$ex = new AMQPExchange($channel);
$ex->setName($exchangeName);

$ex->setType(AMQP_EX_TYPE_DIRECT); //direct類型
$ex->setFlags(AMQP_DURABLE); //持久化
$ex->declare();

//  創建隊列
$queueName = 'queue1';
$q = new AMQPQueue($channel);
$q->setName($queueName);
$q->setFlags(AMQP_DURABLE);
$q->declareQueue();

// 用於綁定隊列和交換機,跟 send.php 中的一致。
$routingKey = 'key_1';
$q->bind($exchangeName,  $routingKey);

//接收消息
$q->consume(function ($envelope, $queue) {
    $msg = $envelope->getBody();
    echo $msg."\n"; //處理消息
}, AMQP_AUTOACK);

$conn->disconnect();

以上代碼保存爲 consume.php

運行代碼

一開始隊列是不存在的,我們需要先啓動 consume.php 來初始化隊列,打開終端,運行

php consume.php

啓動後 , php consume.php 將阻塞監聽隊列消息。
然後打開新終端窗口運行:

php send.php

然後在新 consume.php 所在的終端窗口將看到接收到的消息。

消費 rabbitmq 消息

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章