Download the PHP package comlaude/laravel-amqp without Composer
On this page you can find all versions of the php package comlaude/laravel-amqp. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package laravel-amqp
ComLaude/laravel-amqp
Simple PhpAmqpLib wrapper for interaction with RabbitMQ
Installation
Composer
Add the following to your require part within the composer.json:
or
Integration
Lumen
Create a config folder in the root directory of your Lumen application and copy the content from vendor/comlaude/laravel-amqp/config/amqp.php to config/amqp.php.
Adjust the properties to your needs.
Register the Lumen Service Provider in bootstrap/app.php:
Add Facade Support for Lumen 5.2+
Laravel
Open config/app.php and add the service provider and alias:
Publishing a message
Push message with routing key
Push message with routing key and overwrite properties
Consuming messages
Consume messages forever
Consume messages, with custom settings
Fanout example
Publishing a message
Disable publishing
This is useful for development and sync requirements, if you are using observers or events to trigger messages over AMQP you may want to temporarily disable the publishing of messages. When turning the publishing off the publish method will silently drop the message and return.
Check state
Disable
Enable
Remote procedure call server and client
RPC is potentially an anti-pattern in a microservices world so do not use it carelessly, nevertheless sometimes you just need that request-response behaviour and you're willing to accept its limitations. Simply return a response from within a consumer handler, if the message is a request from a client, the response will automatically be routed to the correct requestor. There are 2 configurable timeouts to prevent infinite-blocking waits.
-
time to wait for confirmation from server that a job is being worked on, this is a check if anybody is listening at all and should be quite small
- time to wait for the full request to be completed (all messages), be careful to ensure this is large enough if your job is long-lasting or if the number of messages to be handled is large
Server
Client
Consume messages, with dead letter exchange configured
When using the x-dead-letter-exchange
parameter in queue properties the package will additionally:
- declare the
-dlx queue - declare the exchange itself
When the consumer fails or requeues the message for 5 times the message will instead be routed to this new queue via the dead letter exchange.
Credits
- Some concepts were used from https://github.com/bschmitt/laravel-amqp
License
This package is open-sourced software licensed under the MIT license