Merge "[baremetal] Retry keystone.client state on failure"
[fuel.git] / mcp / config / states / openstack_ha
1 #!/bin/bash -e
2 ##############################################################################
3 # Copyright (c) 2017 Mirantis Inc., Enea AB and others.
4 # All rights reserved. This program and the accompanying materials
5 # are made available under the terms of the Apache License, Version 2.0
6 # which accompanies this distribution, and is available at
7 # http://www.apache.org/licenses/LICENSE-2.0
8 ##############################################################################
9
10 CI_DEBUG=${CI_DEBUG:-0}; [[ "${CI_DEBUG}" =~ (false|0) ]] || set -x
11
12 # shellcheck disable=SC1090
13 source "$(dirname "${BASH_SOURCE[0]}")/../../scripts/lib.sh"
14
15 salt -I 'keepalived:cluster' state.sls keepalived -b 1
16 salt -I 'keepalived:cluster' pillar.get keepalived:cluster:instance:VIP:address
17
18 salt -C 'I@rabbitmq:server and *01*' state.sls rabbitmq
19 salt -I 'rabbitmq:server' state.sls rabbitmq
20 salt -I 'rabbitmq:server' cmd.run "rabbitmqctl cluster_status"
21
22 salt -I 'glusterfs:server' state.sls glusterfs.server.service
23 salt -I 'glusterfs:server' state.sls glusterfs.server.setup -b 1
24 salt -I 'glusterfs:server' cmd.run "gluster peer status; gluster volume status" -b 1
25
26 salt -I 'galera:master' state.sls galera
27 salt -I 'galera:slave' state.sls galera
28 salt -I 'galera:master' mysql.status | grep -A1 wsrep_cluster_size
29
30 salt -I 'memcached:server' state.sls memcached
31
32 salt -I 'haproxy:proxy' state.sls haproxy
33 salt -I 'haproxy:proxy' service.status haproxy
34 salt -I 'haproxy:proxy' service.restart rsyslog
35
36 salt -I 'keystone:server' state.sls keystone.server -b 1
37 salt -I 'keystone:server' service.restart apache2
38 wait_for 30 "salt -I 'keystone:client' state.sls keystone.client"
39 salt -I 'keystone:server' cmd.run ". /root/keystonercv3; openstack service list"
40
41 salt -I 'glance:server' state.sls glance -b 1
42 salt -I 'glusterfs:client' state.sls glusterfs.client
43 salt -I 'keystone:server' state.sls keystone.server
44
45 salt -I 'nova:controller' state.sls nova -b 1
46 salt -I 'heat:server' state.sls heat -b 1
47
48 salt -I 'cinder:controller' state.sls cinder -b 1
49 salt -I 'cinder:volume' state.sls cinder
50
51 salt -I 'neutron:server' state.sls neutron -b 1
52 salt -I 'neutron:gateway' state.sls neutron.gateway
53
54 salt -I 'nova:compute' state.sls nova
55
56 salt -I 'mongodb:server' state.sls mongodb || true
57 wait_for 90 "salt -C 'I@mongodb:server and *01*' cmd.run 'mongo localhost:27017/admin'"
58 salt -C 'I@mongodb:server and *01*' cmd.run 'mongo localhost:27017/admin --eval "rs.initiate()"'
59 salt -C 'I@mongodb:server and *01*' state.sls mongodb
60
61 salt -I 'aodh:server' state.sls aodh -b 1
62 salt -I 'ceilometer:server' state.sls ceilometer
63 salt -I 'ceilometer:agent' state.sls ceilometer
64
65 salt -I 'horizon:server' state.sls horizon
66 salt -I 'apache:server' state.sls apache
67 salt -I 'nginx:server' state.sls nginx,sphinx
68
69 clstr_vip_addr=$(salt -C 'I@nginx:server and *01*' --out=yaml \
70   pillar.get _param:cluster_vip_address | awk '{print $2; exit}')
71 salt -C 'I@nginx:server and *01*' cp.push \
72   "/etc/ssl/certs/${clstr_vip_addr}-with-chain.crt" upload_path='certs/os_cacert'
73 cd /etc/ssl/certs && ln -sf /var/cache/salt/master/minions/prx01.*/files/certs/os_cacert
74
75 # glance v1 api is required by orchestra tests
76 salt -I 'glance:server' ini.set_option /etc/glance/glance-api.conf '{DEFAULT: {enable_v1_api: True}}'
77 salt -I 'glance:server' service.restart glance-api