RabbitMQをメッセージのブローカーとして使う
RabbitMQはとても有名なメッセージブローカーで、PostgreSQLの代わりに使うことができます。
PostgreSQLからRabbitMQに切り替える
メッセージブローカーとしてPostgreSQLの代わりにRabbitMQを利用します:
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
メッセンジャー用にRabbitMQサポートを追加する必要があります:
1
$ symfony composer req amqp-messenger
DockerにRabbitMQを追加する
既に予想していたかもしれませんが、RabbitMQをDocker Composeにも追加する必要があります:
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:
Dockerサービスを再起動する
Docker ComposeでRabbitMQ コンテナを扱わせるために、コンテナをすべて停止して再起動します:
1 2
$ docker-compose stop
$ docker-compose up -d
RabbitMQのWeb管理画面を使う
RabbitMQを通っていくキューやメッセージを見たければ、RabbitMQのWeb管理画面を開きます:
1
$ symfony open:local:rabbitmq
あるいはWebデバッグツールバーからも見ることができます:
RabbitMQの管理画面には guest
/guest
アカウントを使ってログインします:
RabbitMQをデプロイする
RabbitMQをプロダクションサーバーに追加するには、サービスのリストに追加します:
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
Webコンテナの設定でも参照し、 amqp
PHP拡張を有効にします:
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: |
RabbitMQサービスがプロジェクトにインストールされると、トンネルを使ってWeb管理画面にアクセスできるようになります:
1 2 3 4 5
$ symfony cloud:tunnel:open
$ symfony open:remote:rabbitmq
# when done
$ symfony cloud:tunnel:close
This work, including the code samples, is licensed under a
Creative Commons BY-NC-SA 4.0 license.