1 heat_template_version: pike
4 OpenStack containerized Rabbitmq service
10 DockerRabbitmqConfigImage:
11 description: The container image to use for the rabbitmq config_volume
15 description: Mapping of service endpoint -> protocol. Typically set
16 via parameter_defaults in the resource registry.
20 description: Dictionary packing service data
24 description: Mapping of service_name -> network name. Typically set
25 via parameter_defaults in the resource registry. This
26 mapping overrides those in ServiceNetMapDefaults.
37 description: Role name on which the service is applied
41 description: Parameters specific to the role
47 type: ../../../puppet/services/rabbitmq.yaml
49 EndpointMap: {get_param: EndpointMap}
50 ServiceData: {get_param: ServiceData}
51 ServiceNetMap: {get_param: ServiceNetMap}
52 DefaultPasswords: {get_param: DefaultPasswords}
53 RoleName: {get_param: RoleName}
54 RoleParameters: {get_param: RoleParameters}
58 description: Role data for the Rabbitmq API role.
60 service_name: {get_attr: [RabbitmqBase, role_data, service_name]}
63 - {get_attr: [RabbitmqBase, role_data, config_settings]}
64 - rabbitmq::service_manage: false
65 tripleo::profile::pacemaker::rabbitmq_bundle::rabbitmq_docker_image: &rabbitmq_image_pcmklatest
69 data: {get_param: DockerRabbitmqImage}
70 expression: $.data.rightSplit(separator => ":", maxSplits => 1)[0]
72 tripleo::profile::pacemaker::rabbitmq_bundle::control_port: 3122
73 tripleo.rabbitmq.firewall_rules:
74 '109 rabbitmq-bundle':
80 logging_source: {get_attr: [RabbitmqBase, role_data, logging_source]}
81 logging_groups: {get_attr: [RabbitmqBase, role_data, logging_groups]}
82 step_config: &step_config
83 get_attr: [RabbitmqBase, role_data, step_config]
84 service_config_settings: {get_attr: [RabbitmqBase, role_data, service_config_settings]}
85 # BEGIN DOCKER SETTINGS
87 config_volume: rabbitmq
89 step_config: *step_config
90 config_image: {get_param: DockerRabbitmqConfigImage}
92 /var/lib/kolla/config_files/rabbitmq.json:
93 command: /usr/sbin/pacemaker_remoted
95 - dest: /etc/libqb/force-filesystem-sockets
99 - source: "/var/lib/kolla/config_files/src/*"
102 preserve_properties: true
103 - source: "/var/lib/kolla/config_files/src-tls/*"
107 preserve_properties: true
109 - path: /var/lib/rabbitmq
110 owner: rabbitmq:rabbitmq
112 - path: /var/log/rabbitmq
113 owner: rabbitmq:rabbitmq
115 - path: /etc/pki/tls/certs/rabbitmq.crt
116 owner: rabbitmq:rabbitmq
119 - path: /etc/pki/tls/private/rabbitmq.key
120 owner: rabbitmq:rabbitmq
123 # When using pacemaker we don't launch the container, instead that is done by pacemaker
129 image: {get_param: DockerRabbitmqImage}
133 - /var/lib/kolla/config_files/rabbitmq.json:/var/lib/kolla/config_files/config.json:ro
134 - /var/lib/config-data/puppet-generated/rabbitmq/:/var/lib/kolla/config_files/src:ro
135 - /etc/hosts:/etc/hosts:ro
136 - /etc/localtime:/etc/localtime:ro
137 - /var/lib/rabbitmq:/var/lib/rabbitmq
139 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
140 - KOLLA_BOOTSTRAP=True
144 - - 'RABBITMQ_CLUSTER_COOKIE'
147 expression: $.data.passwords.where($ != '').first()
150 - {get_param: RabbitCookie}
151 - {get_param: [DefaultPasswords, rabbit_cookie]}
162 "/usr/bin/docker tag 'RABBITMQ_IMAGE' 'RABBITMQ_IMAGE_PCMKLATEST'"
164 RABBITMQ_IMAGE: {get_param: DockerRabbitmqImage}
165 RABBITMQ_IMAGE_PCMKLATEST: *rabbitmq_image_pcmklatest
166 image: {get_param: DockerRabbitmqImage}
168 - /etc/hosts:/etc/hosts:ro
169 - /etc/localtime:/etc/localtime:ro
170 - /dev/shm:/dev/shm:rw
171 - /etc/sysconfig/docker:/etc/sysconfig/docker:ro
172 - /usr/bin:/usr/bin:ro
173 - /var/run/docker.sock:/var/run/docker.sock:rw
175 rabbitmq_init_bundle:
187 - - "cp -a /tmp/puppet-etc/* /etc/puppet; echo '{\"step\": 2}' > /etc/puppet/hieradata/docker.json"
188 - "FACTER_uuid=docker puppet apply --tags file,file_line,concat,augeas,TAGS -v -e 'CONFIG'"
190 TAGS: 'pacemaker::resource::bundle,pacemaker::property,pacemaker::resource::ocf,pacemaker::constraint::order,pacemaker::constraint::colocation'
191 CONFIG: 'include ::tripleo::profile::base::pacemaker;include ::tripleo::profile::pacemaker::rabbitmq_bundle'
192 image: {get_param: DockerRabbitmqImage}
194 - /etc/hosts:/etc/hosts:ro
195 - /etc/localtime:/etc/localtime:ro
196 - /etc/puppet:/tmp/puppet-etc:ro
197 - /usr/share/openstack-puppet/modules:/usr/share/openstack-puppet/modules:ro
198 - /etc/corosync/corosync.conf:/etc/corosync/corosync.conf:ro
199 - /dev/shm:/dev/shm:rw
201 - name: create /var/lib/rabbitmq
203 path: /var/lib/rabbitmq
205 - name: stop the Erlang port mapper on the host and make sure it cannot bind to the port used by container
207 echo 'export ERL_EPMD_ADDRESS=127.0.0.1' > /etc/rabbitmq/rabbitmq-env.conf
208 echo 'export ERL_EPMD_PORT=4370' >> /etc/rabbitmq/rabbitmq-env.conf
209 for pid in $(pgrep epmd); do if [ "$(lsns -o NS -p $pid)" == "$(lsns -o NS -p 1)" ]; then kill $pid; break; fi; done
211 get_attr: [RabbitmqBase, role_data, metadata_settings]
213 - name: get bootstrap nodeid
215 command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
216 register: bootstrap_node
217 - name: set is_bootstrap_node fact
219 set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
220 - name: Check cluster resource status
223 resource: {get_attr: [RabbitmqBase, role_data, service_name]}
227 register: rabbitmq_res
228 - name: Disable the rabbitmq cluster resource.
231 resource: {get_attr: [RabbitmqBase, role_data, service_name]}
233 wait_for_resource: true
236 until: output.rc == 0
237 when: is_bootstrap_node and rabbitmq_res|succeeded
238 - name: Delete the stopped rabbitmq cluster resource.
241 resource: {get_attr: [RabbitmqBase, role_data, service_name]}
243 wait_for_resource: true
246 until: output.rc == 0
247 when: is_bootstrap_node and rabbitmq_res|succeeded
248 - name: Disable rabbitmq service
250 service: name=rabbitmq-server enabled=no