|  | {% from 'virtual-mcp-ocata-ceph-offline/underlay.yaml' import HOSTNAME_CFG01 with context %} | 
|  |  | 
|  | - description: remove apparmor | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | '*' cmd.run 'service apparmor stop; service apparmor teardown; update-rc.d -f apparmor remove; apt-get -y remove apparmor' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 10} | 
|  | skip_fail: true | 
|  |  | 
|  | # Install support services | 
|  | - description: Install keepalived on ctl01 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@keepalived:cluster and *01*' state.sls keepalived | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 10} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Install keepalived | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@keepalived:cluster' state.sls keepalived | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 10} | 
|  | skip_fail: true | 
|  |  | 
|  | - description: Install glusterfs | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@glusterfs:server' state.sls glusterfs.server.service | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Setup glusterfs on primary controller | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@glusterfs:server' state.sls glusterfs.server.setup -b 1 | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 2, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check the gluster status | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@glusterfs:server' cmd.run 'gluster peer status; gluster volume status' -b 1 | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install RabbitMQ on ctl01 | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@rabbitmq:server and *01*' state.sls rabbitmq | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install RabbitMQ | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@rabbitmq:server' state.sls rabbitmq | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check the rabbitmq status | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@rabbitmq:server' cmd.run 'rabbitmqctl cluster_status' | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Galera on first server | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@galera:master' state.sls galera | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install Galera on other servers | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@galera:slave' state.sls galera -b 1 | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check mysql status | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@galera:*' mysql.status | grep -A1 -e "wsrep_incoming_addresses\|wsrep_cluster_size" | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: true | 
|  |  | 
|  |  | 
|  | - description: Install haproxy | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@haproxy:proxy' state.sls haproxy | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check haproxy status | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@haproxy:proxy' service.status haproxy | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Restart rsyslog | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@haproxy:proxy' service.restart rsyslog | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Install memcached on all controllers | 
|  | cmd: salt --hard-crash --state-output=mixed --state-verbose=False | 
|  | -C 'I@memcached:server' state.sls memcached | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 1, delay: 5} | 
|  | skip_fail: false | 
|  |  | 
|  | - description: Check the VIP | 
|  | cmd: | | 
|  | OPENSTACK_CONTROL_ADDRESS=`salt-call --out=newline_values_only pillar.get _param:openstack_control_address`; | 
|  | echo "_param:openstack_control_address (vip): ${OPENSTACK_CONTROL_ADDRESS}"; | 
|  | salt --hard-crash --state-output=mixed --state-verbose=False -C 'I@keepalived:cluster' cmd.run "ip a | grep ${OPENSTACK_CONTROL_ADDRESS}" | grep -B1 ${OPENSTACK_CONTROL_ADDRESS} | 
|  | node_name: {{ HOSTNAME_CFG01 }} | 
|  | retry: {count: 3, delay: 10} | 
|  | skip_fail: false |