2017-10-19 3 views
2

Voici mon problème. Je veux créer une application de jouet en mode Publish/Subscribe, j'ai pris celui-là comme un exemple. Mais je veux implémenter mes consommateurs avec un accusé de réception. Je m'attends au comportement suivant: après le décès d'un de mes clients, je réexécute ce script dans une console et le message est traité.RabbitMQ: réutiliser le message non-acked dans l'échange de fanout

Voici un code pour un éditeur:

<?php 

require_once __DIR__ . '/vendor/autoload.php'; 

use PhpAmqpLib\Connection\AMQPStreamConnection; 
use PhpAmqpLib\Message\AMQPMessage; 

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

$channel->exchange_declare('logs', 'fanout', false, true, false); 

$data = implode(' ', array_slice($argv, 1)); 
if(empty($data)) $data = "info: Hello World!"; 
$msg = new AMQPMessage($data); 

$channel->basic_publish($msg, 'logs'); 

echo " [x] Sent ", $data, "\n"; 

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

Et voici un code pour un abonné:

<?php 

require_once __DIR__ . '/vendor/autoload.php'; 

use PhpAmqpLib\Connection\AMQPStreamConnection; 

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

$channel->exchange_declare('logs', 'fanout', false, true, false); 

$channel->queue_declare("queue1", false, true, true, false); 

$channel->queue_bind("queue1", 'logs'); 

echo ' [*] Waiting for logs. To exit press CTRL+C', "\n"; 

$callback = function($msg){ 
    echo ' [x] ', $msg->body, "\n"; 
    die(); 
    $msg->delivery_info['channel']->basic_ack($msg->delivery_info['delivery_tag']); 
}; 

$channel->basic_consume("queue1", '', false, false, false, false, $callback); 

while(count($channel->callbacks)) { 
    $channel->wait(); 
} 

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

Quand je lance, [x] info: Hello World! est affiché dans la console d'un abonné, que je ne Attendez-vous à ce que ce message ne soit pas reconnu puisque le script meurt simplement. Après l'avoir réexécuté, aucun message n'est consommé. Et le web-panel rabbitMQ montre qu'il n'y a pas non plus de messages non-récupérés.

Qu'est-ce que je fais mal?

Répondre

0

C'est parce que vous avez déclaré un exclusive queue. Il est supprimé une fois la connexion perdue. Ainsi, lorsque vous avez appuyé sur Ctrl + C, la file d'attente a été supprimée et lorsque vous réexécutez ce script, il y avait une nouvelle file d'attente sans message. Vous devez donc déclarer une file d'attente non exclusive:

$channel->queue_declare("queue1", false, true, false, false);