Merge "Add networking-vpp ML2 mechanism driver support"
[apex-tripleo-heat-templates.git] / docker / services / rabbitmq.yaml
1 heat_template_version: pike
2
3 description: >
4   OpenStack containerized Rabbitmq service
5
6 parameters:
7   DockerNamespace:
8     description: namespace
9     default: 'tripleoupstream'
10     type: string
11   DockerRabbitmqImage:
12     description: image
13     default: 'centos-binary-rabbitmq:latest'
14     type: string
15   EndpointMap:
16     default: {}
17     description: Mapping of service endpoint -> protocol. Typically set
18                  via parameter_defaults in the resource registry.
19     type: json
20   ServiceNetMap:
21     default: {}
22     description: Mapping of service_name -> network name. Typically set
23                  via parameter_defaults in the resource registry.  This
24                  mapping overrides those in ServiceNetMapDefaults.
25     type: json
26   DefaultPasswords:
27     default: {}
28     type: json
29   RabbitCookie:
30     type: string
31     default: ''
32     hidden: true
33
34 resources:
35
36   ContainersCommon:
37     type: ./containers-common.yaml
38
39   RabbitmqBase:
40     type: ../../puppet/services/rabbitmq.yaml
41     properties:
42       EndpointMap: {get_param: EndpointMap}
43       ServiceNetMap: {get_param: ServiceNetMap}
44       DefaultPasswords: {get_param: DefaultPasswords}
45
46 outputs:
47   role_data:
48     description: Role data for the Rabbitmq API role.
49     value:
50       service_name: {get_attr: [RabbitmqBase, role_data, service_name]}
51       # RabbitMQ plugins initialization occurs on every node
52       config_settings:
53         map_merge:
54           - {get_attr: [RabbitmqBase, role_data, config_settings]}
55           - rabbitmq::admin_enable: false
56       step_config: &step_config
57         list_join:
58           - "\n"
59           - - "['Rabbitmq_policy', 'Rabbitmq_user'].each |String $val| { noop_resource($val) }"
60             - get_attr: [RabbitmqBase, role_data, step_config]
61       service_config_settings: {get_attr: [RabbitmqBase, role_data, service_config_settings]}
62       # BEGIN DOCKER SETTINGS
63       puppet_config:
64         config_volume: rabbitmq
65         step_config: *step_config
66         config_image: &rabbitmq_image
67           list_join:
68             - '/'
69             - [ {get_param: DockerNamespace}, {get_param: DockerRabbitmqImage} ]
70       kolla_config:
71         /var/lib/kolla/config_files/rabbitmq.json:
72           command: /usr/lib/rabbitmq/bin/rabbitmq-server
73           permissions:
74             - path: /var/lib/rabbitmq
75               owner: rabbitmq:rabbitmq
76               recurse: true
77       docker_config:
78         # Kolla_bootstrap runs before permissions set by kolla_config
79         step_1:
80           rabbitmq_init_logs:
81             start_order: 0
82             image: *rabbitmq_image
83             privileged: false
84             user: root
85             volumes:
86               - /var/log/containers/rabbitmq:/var/log/rabbitmq
87             command: ['/bin/bash', '-c', 'chown -R rabbitmq:rabbitmq /var/log/rabbitmq']
88           rabbitmq_bootstrap:
89             start_order: 1
90             image: *rabbitmq_image
91             net: host
92             privileged: false
93             volumes:
94               list_concat:
95                 - {get_attr: [ContainersCommon, volumes]}
96                 -
97                   - /var/lib/kolla/config_files/rabbitmq.json:/var/lib/kolla/config_files/config.json:ro
98                   - /var/lib/config-data/rabbitmq/etc/rabbitmq/:/etc/rabbitmq/:ro
99                   - /var/lib/rabbitmq:/var/lib/rabbitmq
100                   - /var/log/containers/rabbitmq:/var/log/rabbitmq
101             environment:
102               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
103               - KOLLA_BOOTSTRAP=True
104               -
105                 list_join:
106                   - '='
107                   - - 'RABBITMQ_CLUSTER_COOKIE'
108                     -
109                       yaql:
110                         expression: $.data.passwords.where($ != '').first()
111                         data:
112                           passwords:
113                             - {get_param: RabbitCookie}
114                             - {get_param: [DefaultPasswords, rabbit_cookie]}
115           rabbitmq:
116             start_order: 2
117             image: *rabbitmq_image
118             net: host
119             privileged: false
120             restart: always
121             volumes:
122               list_concat:
123                 - {get_attr: [ContainersCommon, volumes]}
124                 -
125                   - /var/lib/kolla/config_files/rabbitmq.json:/var/lib/kolla/config_files/config.json:ro
126                   - /var/lib/config-data/rabbitmq/etc/rabbitmq/:/etc/rabbitmq/:ro
127                   - /var/lib/rabbitmq:/var/lib/rabbitmq
128                   - /var/log/containers/rabbitmq:/var/log/rabbitmq
129             environment:
130               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
131       docker_puppet_tasks:
132         # RabbitMQ users and policies initialization occurs only on single node
133         step_1:
134           config_volume: 'rabbit_init_tasks'
135           puppet_tags: 'rabbitmq_policy,rabbitmq_user'
136           step_config: 'include ::tripleo::profile::base::rabbitmq'
137           config_image: *rabbitmq_image
138           volumes:
139             - /var/lib/config-data/rabbitmq/etc/:/etc/
140             - /var/lib/rabbitmq:/var/lib/rabbitmq:ro
141       host_prep_tasks:
142         - name: create persistent directories
143           file:
144             path: "{{ item }}"
145             state: directory
146           with_items:
147             - /var/log/containers/rabbitmq
148             - /var/lib/rabbitmq
149       upgrade_tasks:
150         - name: Stop and disable rabbitmq service
151           tags: step2
152           service: name=rabbitmq-server state=stopped enabled=no