Download the PHP package enqueue/messenger-adapter without Composer
On this page you can find all versions of the php package enqueue/messenger-adapter. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download enqueue/messenger-adapter
More information about enqueue/messenger-adapter
Files in enqueue/messenger-adapter
Package messenger-adapter
Short Description Enqueue adapter for Symfony Messenger component
License MIT
Homepage http://symfony.com
Informations about the package messenger-adapter
Enqueue's transport for Symfony Messenger component
This Symfony Messenger transport allows you to use Enqueue to send and receive your messages from all the supported brokers.
Usage
-
Install the transport
-
Configure the Enqueue bundle as you would normaly do (see Enqueue's Bundle documentation). If you are using the recipes, you should just have to configure the environment variables to configure the
default
Enqueue transport: -
Configure Messenger's transport (that we will name
amqp
) to use Enqueue'sdefault
transport: -
Route the messages that have to go through the message queue:
- Consume!
Advanced usage
Configure the queue(s) and exchange(s)
In the transport DSN, you can add extra configuration. Here is the common reference DSN (note that the values are just for the example):
Setting Custom Configuration on your Message
Each Enqueue transport (e.g. amqp, redis, etc) has its own message object
that can normally be configured by calling setter methods (e.g.
$message->setDeliveryDelay(5000)
). But in Messenger, you don't have access
to these objects directly. Instead, you can set them indirectly via
the TransportConfiguration
stamp:
Send a message on a specific topic
You can send a message on a specific topic using TransportConfiguration
envelope item with your message:
Use AMQP topic exchange
See https://www.rabbitmq.com/tutorials/tutorial-five-php.html
You can use specific topic and queue options to configure your AMQP exchange in topic
mode and bind it:
Here is the way to send a message with a routing key matching this consumer:
Configure custom Kafka message
Here is the way to send a message with with some custom options:
$this->bus->dispatch((new Envelope($message))->with(new TransportConfiguration([
'topic' => 'test_topic_name',
'metadata' => [
'key' => 'foo.bar',
'partition' => 0,
'timestamp' => (new \DateTimeImmutable())->getTimestamp(),
'messageId' => uniqid('kafka_', true),
]
])))
All versions of messenger-adapter with dependencies
symfony/messenger Version ^4.3|^5
symfony/options-resolver Version ^3.4|^4.2|^5
enqueue/amqp-tools Version ^0.10