Set up RabbitMQ service
The Message Queue Framework (MQF) is a system within 51黑料不打烊 Commerce that allows a module to publish messages to queues. It also defines the consumers that receive the messages asynchronously.
The MQF uses as the messaging broker, which provides a scalable platform for sending and receiving messages. It also includes a mechanism for storing undelivered messages. RabbitMQ is based on the Advanced Message Queuing Protocol (AMQP) 0.9.1 specification.
QUEUE_CONFIGURATION environment variable to connect it to your site.Use the following instructions for service setup on Pro Integration environments and Starter environments, including the master branch.
To enable RabbitMQ:
- 
                  Add the required name, type, and disk value (in MB) to the .magento/services.yamlfile along with the installed RabbitMQ version.code language-yaml rabbitmq: type: rabbitmq:<version> disk: 1024
- 
                  Configure the relationships in the .magento.app.yamlfile.code language-yaml relationships: rabbitmq: "rabbitmq:rabbitmq"
- 
                  Add, commit, and push your code changes. code language-bash git add .magento/services.yaml .magento.app.yamlcode language-bash git commit -m "Enable RabbitMQ service"code language-bash git push origin <branch-name>
services.yaml and .magento.app.yaml configuration files. See Change service version for guidance on upgrading or downgrading a service.Connect to RabbitMQ for debugging
For debugging purposes, it is useful to directly connect to a service instance in one of the following ways:
- Connect from your local development environment
- Connect from the application
- Connect from your PHP application
Connect from your local development environment
- 
                  Log in to the magento-cloudCLI and project:code language-bash magento-cloud login
- 
                  Check out the environment with RabbitMQ installed and configured. code language-bash magento-cloud environment:checkout <environment-id>
- 
                  Use SSH to connect to the Cloud environment: code language-bash magento-cloud ssh
- 
                  Retrieve the RabbitMQ connection details and login credentials from the $MAGENTO_CLOUD_RELATIONSHIPS variable: code language-bash echo $MAGENTO_CLOUD_RELATIONSHIPS | base64 -d | json_ppor code language-bash php -r 'print_r(json_decode(base64_decode($_ENV["MAGENTO_CLOUD_RELATIONSHIPS"])));'In the response, find the RabbitMQ information, for example: code language-json { "rabbitmq" : [ { "password" : "guest", "ip" : "246.0.129.2", "scheme" : "amqp", "port" : 5672, "host" : "rabbitmq.internal", "username" : "guest" } ] }
- 
                  Enable local port forwarding to RabbitMQ (if your project is located on a different region such as US-3, EU-5, or AP-3 region, substitute us-3/eu-5/ap-3forus)code language-bash ssh -L <port-number>:rabbitmq.internal:<port-number> <project-ID>-<branch-ID>@ssh.us.magentosite.cloudAn example for accessing the RabbitMQ management web interface at http://localhost:15672is:code language-bash ssh -L 15672:rabbitmq.internal:15672 <project-ID>-<branch-ID>@ssh.us.magentosite.cloud
- 
                  While the session is open, you can start a RabbitMQ client of your choice from your local workstation, configured to connect to the localhost:<portnumber>using the port number, username, and password information from the MAGENTO_CLOUD_RELATIONSHIPS variable.
Connect from the application
To connect to RabbitMQ running in an application, install a client, such as , as a project dependency in your .magento.app.yaml file.
For example,
dependencies:
    ruby:
        amqp-utils: "0.5.1"
When you log in to your PHP container, you enter any amqp- command available to manage your queues.
Connect from your PHP application
To connect to RabbitMQ using your PHP application, add a PHP library to your source tree.