RabbitMQ als Message-Broker nutzen
RabbitMQ ist ein sehr beliebter Message-Broker den Du als Alternative zu PostgreSQL nutzen kannst.
Von PostgreSQL zu RabbitMQ wechseln
Um RabbitMQ anstelle von PostgreSQL als Message-Broker zu nutzen:
1 2 3 4 5 6 7 8 9 10 11 12 13 14
--- a/config/packages/messenger.yaml
+++ b/config/packages/messenger.yaml
@@ -5,10 +5,7 @@ framework:
         transports:
             # https://symfony.com/doc/current/messenger.html#transport-configuration
             async:
-                dsn: '%env(MESSENGER_TRANSPORT_DSN)%'
-                options:
-                    use_notify: true
-                    check_delayed_interval: 60000
+                dsn: '%env(RABBITMQ_URL)%'
                 retry_strategy:
                     max_retries: 3
                     multiplier: 2
    Wir müssen auch RabbitMQ-Unterstützung für Messenger hinzufügen:
1
$ symfony composer req amqp-messenger
    Füge RabbitMQ zum Docker-Stack hinzu
Wie Du sicherlich schon erraten hast, müssen wir RabbitMQ auch in den Docker Compose-Stack aufnehmen:
1 2 3 4 5 6 7 8 9 10 11 12 13
--- a/docker-compose.yml
+++ b/docker-compose.yml
@@ -19,6 +19,10 @@ services:
     image: redis:5-alpine
     ports: [6379]
+  rabbitmq:
+    image: rabbitmq:3.7-management
+    ports: [5672, 15672]
+
 volumes:
 ###> doctrine/doctrine-bundle ###
   db-data:
    Neustarten der Docker Dienste
Um Docker Compose zu zwingen den RabbitMQ-Container zu berücksichtigen, stoppe den Container und starte ihn neu:
1 2
$ docker-compose stop
$ docker-compose up -d
    Die RabbitMQ Web-Verwaltungs-Oberfläche erkunden
Wenn Du die Queues und Nachrichten sehen willst, die durch RabbitMQ verwaltet werden, öffne seine Web-Verwaltungs-Oberfläche:
1
$ symfony open:local:rabbitmq
    Oder mit der Web-Debug-Toolbar:
    Nutze guest/guest als Login für die RabbitMQ Verwaltungs-Oberfläche:
    RabbitMQ deployen
Man kann RabbitMQ auf dem Produktivsystem aktivieren, indem man es zu der Liste der Dienste hinzufügt:
1 2 3 4 5 6 7 8 9 10 11
--- a/.platform/services.yaml
+++ b/.platform/services.yaml
@@ -18,3 +18,8 @@ files:
 rediscache:
     type: redis:5.0
+
+queue:
+    type: rabbitmq:3.7
+    disk: 1024
+    size: S
    Verweise auch darauf in der Web-Container-Konfiguration und aktiviere die amqp-PHP-Erweiterung:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
--- a/.platform.app.yaml
+++ b/.platform.app.yaml
@@ -8,6 +8,7 @@ dependencies:
 runtime:
     extensions:
+        - amqp
         - apcu
         - blackfire
         - ctype
@@ -41,6 +42,7 @@ mounts:
 relationships:
     database: "database:postgresql"
     redis: "rediscache:redis"
+    rabbitmq: "queue:rabbitmq"
     
 hooks:
     build: |
    Wenn der RabbitMQ-Dienst in einem Projekt installiert ist, kannst Du auf die Web-Verwaltungs-Oberfläche über einen Tunnel zugreifen:
1 2 3 4 5
$ symfony cloud:tunnel:open
$ symfony open:remote:rabbitmq
# when done
$ symfony cloud:tunnel:close