tanadeau.ansible_role_rabbitmq
RabbitMQ Ansible Role
Forked from https://github.com/jasonroyle/ansible-role-rabbitmq on 2018-08-20 to support EL 7 and RabbitMQ 3.7+.
Version
See:
Set the rabbitmq_version variable to define the version of RabbitMQ to install.
rabbitmq_version: '3.8.1'
Users
See:
Set the rabbitmq_users variable to define an array of present users.
rabbitmq_users:
- user: admin
password: admin
tags: administrator
| parameter | required | default | choices | comments |
|---|---|---|---|---|
| configure_priv | no | .* | ||
| password | yes | |||
| read_priv | no | .* | ||
| tags | no | |||
| user | yes | |||
| vhost | no | / | ||
| write_priv | no | .* |
Remove Users
Set the rabbitmq_users_absent variable to define an array of absent users.
rabbitmq_users_absent:
- guest
Virtual Hosts
See:
Set the rabbitmq_vhosts variable to define an array of present virtual hosts.
rabbitmq_vhosts:
- /one
- name: /two
node: rabbit
tracing: no
| parameter | required | default | choices | comments |
|---|---|---|---|---|
| name | yes | |||
| node | no | rabbit | ||
| tracing | no | no |
|
Remove Virtual Hosts
Set the rabbitmq_vhosts_absent variable to define an array of absent virtual hosts.
rabbitmq_vhosts_absent:
- /vhost
Plugins
See:
Set the rabbitmq_plugins variable to define an array of enabled plugins.
rabbitmq_plugins:
- rabbitmq_management
- name: rabbitmq_delayed_message_exchange
url: http://www.rabbitmq.com/community-plugins/v3.6.x/rabbitmq_delayed_message_exchange-0.0.1.ez
| parameter | required | default | choices | comments |
|---|---|---|---|---|
| name | yes | |||
| url | no | Installs the plugin |
Disable Plugins
Set the rabbitmq_plugins_disabled variable to disable plugins.
rabbitmq_plugins_disabled:
- rabbitmq_management
Configuration
See:
Set the rabbitmq_config variable to define the configuration.
rabbitmq_config:
listeners.tcp.default: 5672
Set the rabbitmq_env variable to define the environment variables. Note that the keys should not contain the
"RABBITMQ_" prefix.
rabbitmq_env:
DIST_PORT: 25672
Cluster
See:
Set the rabbitmq_cluster variable to enable clustering.
As the above clustering documentation is pretty hard to grasp I suggest reading of
https://computingforgeeks.com/how-to-configure-rabbitmq-cluster-on-ubuntu-18-04-lts/
for quick start. And then defined minimum variable as below where the
rabbitmq1 is the short hostname of the master node.
rabbitmq_cluster: yes
# shortname dns only
rabbitmq_cluster_master: "rabbit@rabbitmq1"
Please note that the default behaviour is:
- The first node of the host group is the master
- The ha policy is to replicate the queue for all nodes
- Replacing non-master nodes is supported - just destroy the non-master node and re-launch.
- Switching master node to other node is not supported unless you have to do it manually or rebuild the whole cluster.
Erlang Cookie
Set the rabbitmq_erlang_cookie variable to define the Erlang cookie.
rabbitmq_erlang_cookie: g9avtqdzdm2p5oe9
License
MIT
ansible-galaxy install tanadeau.ansible_role_rabbitmq