Run RabbitMQ with the management plugin enabled:
docker run -d \
--name rabbitmq \
-p 5672:5672 \
-p 15672:15672 \
rabbitmq:managementThe connexion string is amqp://localhost:5672
You can connect to your instance using RabbitGUI at http://localhost:15672 (guest/guest)

Create a docker-compose.yml file with custom credentials and persistent storage:
version: '3'
services:
rabbitmq:
image: rabbitmq:management
container_name: rabbitmq
ports:
- "5672:5672"
- "15672:15672"
environment:
RABBITMQ_DEFAULT_USER: user
RABBITMQ_DEFAULT_PASS: password
volumes:
- rabbitmq_data:/var/lib/rabbitmq
volumes:
rabbitmq_data:The connexion string is amqp://user:password@localhost:5672
You can connect to your instance using RabbitGUI at http://localhost:15672 (user/password)
Add the php-amqplib package to your project using Composer:
composer require php-amqplib/php-amqplibYou can publish directly to a queue using the basic_publish method:
<?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->queue_declare('my_queue', false, false, false, false);
$msg = new AMQPMessage('Hello RabbitGUI!');
$channel->basic_publish($msg, '', 'my_queue');
$channel->close();
$connection->close();Your consumer can listen to messages from a queue using the basic_consume method:
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->queue_declare('my_queue', false, false, false, false);
$callback = function ($msg) {
echo "Message: " . $msg->body . "\n";
};
$channel->basic_consume('my_queue', '', false, true, false, false, $callback);
while ($channel->is_consuming()) {
$channel->wait();
}
$channel->close();
$connection->close();A direct exchange routes messages to queues based on exact routing key matches:
<?php
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare('my_exchange', 'direct', false, false, false);
$channel->queue_declare('my_queue', false, false, false, false);
$channel->queue_bind('my_queue', 'my_exchange', 'my.routing.key');
$msg = new AMQPMessage('Hello RabbitGUI!');
$channel->basic_publish($msg, 'my_exchange', 'my.routing.key');
$callback = function ($msg) {
echo "Message: " . $msg->body . "\n";
};
$channel->basic_consume('my_queue', '', false, true, false, false, $callback);A fanout exchange broadcasts messages to all bound queues, ignoring routing keys:
<?php
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare('my_exchange', 'fanout', false, false, false);
$channel->queue_declare('my_queue', false, false, false, false);
$channel->queue_bind('my_queue', 'my_exchange', '');
$msg = new AMQPMessage('Hello RabbitGUI!');
$channel->basic_publish($msg, 'my_exchange', '');
$callback = function ($msg) {
echo "Message: " . $msg->body . "\n";
};
$channel->basic_consume('my_queue', '', false, true, false, false, $callback);A topic exchange routes messages based on wildcard pattern matching (* for one word, # for zero or more words):
<?php
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare('my_exchange', 'topic', false, false, false);
$channel->queue_declare('my_queue', false, false, false, false);
$channel->queue_bind('my_queue', 'my_exchange', '*.routing.*');
$msg = new AMQPMessage('Hello RabbitGUI!');
$channel->basic_publish($msg, 'my_exchange', 'my.routing.key');
$callback = function ($msg) {
echo "Message: " . $msg->body . "\n";
};
$channel->basic_consume('my_queue', '', false, true, false, false, $callback);RabbitMQ will dequeue messages as soon as they've been sent down the wire.
$channel->basic_consume('my_queue', '', false, true, false, false, $callback);
// ^^^^
// auto_ack = trueManually acknowledge messages after processing to ensure they are removed from the queue:
$callback = function ($msg) {
// Process message
$msg->ack();
};
$channel->basic_consume('my_queue', '', false, false, false, false, $callback);
// ^^^^^
// auto_ack = falseReject a message and put it back in the queue for reprocessing:
$callback = function ($msg) {
// Process message
$msg->nack(true); // requeue = true
};
$channel->basic_consume('my_queue', '', false, false, false, false, $callback);Reject a message and discard it (sends to dead letter queue if configured):
$callback = function ($msg) {
// Process message
$msg->nack(false); // requeue = false
};
$channel->basic_consume('my_queue', '', false, false, false, false, $callback);Configure a queue with a dead letter exchange to catch rejected or expired messages:
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Wire\AMQPTable;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
// Create the dead letter exchange and queue
$channel->exchange_declare('dlx_exchange', 'direct', false, false, false);
$channel->queue_declare('dead_letter_queue', false, false, false, false);
$channel->queue_bind('dead_letter_queue', 'dlx_exchange', '');
// Create main queue with dead letter configuration
$args = new AMQPTable([
'x-dead-letter-exchange' => 'dlx_exchange',
'x-dead-letter-routing-key' => ''
]);
$channel->queue_declare('my_queue', false, false, false, false, $args);
Cheat sheetRabbitMQ Java Cheat-SheetA comprehensive guide to using RabbitMQ with Java, including setup, producers, consumers, exchanges, and message handling
Cheat sheetRabbitMQ Python Cheat-SheetA comprehensive guide to using RabbitMQ with Python, including setup, producers, consumers, exchanges, and message handling
Cheat sheetRabbitMQ Golang Cheat-SheetEverything you need to know to get started with RabbitMQ in Go and Docker with code examples ready to go.Debug, monitor, and manage RabbitMQ with a modern developer interface.
Try now
ProductDebugging policies in RabbitMQWhile rules regarding which policies are applied to which queues are simple, visually understanding what is going on when something does not behave as expected might be tricky
ProductHow to introspect dead-letter queues with RabbitMQBy design, RabbitMQ has no API to peek at arbitrary messages, search for a specific one, or pick one at random. RabbitGUI is a tool that lets you introspect your dead-letter queues easily
RabbitMQ tutorialProperly setting up dead-letter queues in RabbitMQLearn how to set up dead-letter queues in RabbitMQ, including creating a dead-letter exchange, binding it to a queue, and managing rejected messages via policies