RabbitMQ交換機Direct型別工作原理和PHP樣例程式碼
阿新 • • 發佈:2019-01-07
1 RabbitMQ交換機Direct型別工作原理
direct型別的Exchange路由規則也很簡單,它會把訊息路由到那些binding key與routing key完全匹配的Queue中
1 當生產者,投遞訊息時候,使用exchange_clevercode交換機,routing key = route_clevercode1。這時候發現exchange_clevercode交換機,binding key = route_clevercode1有queue_clevercode1和queue_clevercode2兩個佇列。
訊息將會同投遞到queue_clevercode1和queue_clevercode2兩個佇列這兩個佇列中。
2 當生產者,投遞訊息時候,使用exchange_clevercode交換機,routing key = route_clevercode2。這時候發現exchange_clevercode交換機,binding key = route_clevercode2有queue_clevercode2一個佇列。
訊息將會同投遞到queue_clevercode2一個佇列中。
3 當生產者,投遞訊息時候,使用exchange_clevercode交換機,routing key = route_clevercode3。這時候發現exchange_clevercode交換機,binding key = route_clevercode3有queue_clevercode2一個佇列。
訊息將會同投遞到queue_clevercode2一個佇列中。
2 PHP使用樣例
2.1 安裝composer
注意使用非root使用者安裝composer。/Data/apps/php/bin/php,是php所在bin位置。
$ curl -sS https://getcomposer.org/installer | /Data/apps/php/bin/php
$ vim composer.json
{
"require": {
"videlalvaro/php-amqplib": "v2.5.1"
}
}
$ /Data/apps/php/bin/php composer.phar install
2.2消費者程序consumer.php
<?php
require_once __DIR__ . '/../../vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPConnection;
//連線
$host = '127.0.0.1';//ip
$port = '5672';//埠
$user = 'guest'; //使用者
$password = 'guest'; //密碼
$vhost = '/'; //空間
$connection = new AMQPConnection($host, $port,$user, $password,$vhost);
$channel = $connection->channel();
/*
name: 交換機名字
type: 交換機型別
passive: false
durable: true // 交換機將在伺服器重啟後生存。
auto_delete: false //通道關閉的時候,交換機不會被刪除
*/
$channel->exchange_declare('exchange_clevercode', 'direct', false, true, false);
/*
name: 佇列名稱
passive: false
durable: true // 佇列是否持久化
exclusive: false // 當前連線不在時,佇列是否自動刪除
auto_delete: false // 沒有consumer時,佇列是否自動刪除
*/
$channel->queue_declare('queue_clevercode', false, true, false, false);
/**
* 繫結佇列到一個交換機
*
* @param string $queue 佇列名稱
* @param string $exchange 交換機名稱
* @param string $routing_key binding路由key
* @param bool $nowait
* @param null $arguments
* @param null $ticket
* @return mixed|null
*/
$channel->queue_bind('queue_clevercode', 'exchange_clevercode', 'routing_clevercode');
/**
* 消費回撥函式
* 處理訊息
*/
function processMessage($msg) {
//處理訊息
echo ' [x] ', $msg->delivery_info['routing_key'], ':', $msg->body, "\n";
}
/**
* 開始一個佇列的消費
*
* @param string $queue
* @param string $consumer_tag
* @param bool $no_local
* @param bool $no_ack
* @param bool $exclusive
* @param bool $nowait
* @param callback|null $callback
* @param int|null $ticket
* @param array $arguments
* @return mixed|string
*/
$channel->basic_consume('queue_clevercode', '', false, true, false, false, 'processMessage');
/**
* //註冊結束時候,關閉連線情況
* @param \PhpAmqpLib\Channel\AMQPChannel $ch
* @param \PhpAmqpLib\Connection\AbstractConnection $conn
*/
function AMQP_shutdown($ch, $conn)
{
$ch->close();
$conn->close();
}
register_shutdown_function('AMQP_shutdown', $channel, $connection);
while (count($channel->callbacks))
{
$channel->wait();
}
2.3 生成者程序
<?php
require_once __DIR__ . '/../../vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPConnection;
use PhpAmqpLib\Message\AMQPMessage;
//連線
$host = '127.0.0.1';//ip
$port = '5672';//埠
$user = 'guest'; //使用者
$password = 'guest'; //密碼
$vhost = '/'; //空間
$connection = new AMQPConnection($host, $port,$user, $password,$vhost);
$channel = $connection->channel();
/*
name: 交換機名字
type: 交換機型別
passive: false
durable: true // 交換機將在伺服器重啟後生存。
auto_delete: false //通道關閉的時候,交換機不會被刪除
*/
$channel->exchange_declare('exchange_clevercode', 'direct', false, true, false);
for($i = 1; $i <= 30;$i++)
{
sleep(1);
/**
* Publishes a message
*
* @param AMQPMessage $msg
* @param string $exchange
* @param string $routing_key
* @param bool $mandatory
* @param bool $immediate
* @param null $ticket
*/
$data = "msg info:{$i}";
$msg = new AMQPMessage($data);
$channel->basic_publish($msg, 'exchange_clevercode', 'routing_clevercode');
echo "send :{$data}\n";
}
$channel->close();
$connection->close();