blob: df28c5a9710701101dce8b9a1149a5b19b1058ea [file] [log] [blame]
Pavel Glazov6e9cbb92018-09-03 12:29:31 +04001{% from 'cookied-mcp-newton-dvr/underlay.yaml' import HOSTNAME_CFG01 with context %}
2{% from 'cookied-mcp-newton-dvr/underlay.yaml' import HOSTNAME_CTL01 with context %}
3{% from 'cookied-mcp-newton-dvr/underlay.yaml' import HOSTNAME_CTL02 with context %}
4{% from 'cookied-mcp-newton-dvr/underlay.yaml' import HOSTNAME_CTL03 with context %}
5{% from 'cookied-mcp-newton-dvr/underlay.yaml' import HOSTNAME_GTW01 with context %}
6{% from 'shared-salt.yaml' import IPV4_NET_EXTERNAL_PREFIX with context %}
7{% from 'shared-salt.yaml' import IPV4_NET_TENANT_PREFIX with context %}
8{% set LAB_CONFIG_NAME = os_env('LAB_CONFIG_NAME') %}
9{% set OVERRIDE_POLICY = os_env('OVERRIDE_POLICY', '') %}
10
11{% import 'shared-openstack.yaml' as SHARED_OPENSTACK with context %}
Pavel Glazov78e6c592018-10-24 12:20:12 +040012{% import 'shared-salt.yaml' as SHARED with context %}
Pavel Glazov6e9cbb92018-09-03 12:29:31 +040013
14# Install OpenStack control services
15
16{%- if OVERRIDE_POLICY != '' %}
17- description: Upload policy override
18 upload:
19 local_path: {{ config.salt_deploy.templates_dir }}{{ LAB_CONFIG_NAME }}/
20 local_filename: overrides-policy.yml
21 remote_path: /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/
22 node_name: {{ HOSTNAME_CFG01 }}
23
24- description: Create custom cluster control class
25 cmd: echo -e "classes:\n- cluster.{{ LAB_CONFIG_NAME }}.openstack.control_orig\n$(cat /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/overrides-policy.yml)" > /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/overrides-policy.yml
26 node_name: {{ HOSTNAME_CFG01 }}
27
28- description: Rename control classes
29 cmd: mv /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/control.yml /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/control_orig.yml &&
30 ln -s /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/overrides-policy.yml /srv/salt/reclass/classes/cluster/{{ LAB_CONFIG_NAME }}/openstack/control.yml &&
31 salt --hard-crash --state-output=mixed --state-verbose=False '*' saltutil.sync_all &&
32 salt --hard-crash --state-output=mixed --state-verbose=False '*' saltutil.refresh_pillar
33 node_name: {{ HOSTNAME_CFG01 }}
34{%- endif %}
35
36# Deploy nginx before openstack services (PROD-22740)
37- description: Deploy nginx proxy
38 cmd: salt --hard-crash --state-output=mixed --state-verbose=False
39 -C 'I@nginx:server' state.sls nginx
40 node_name: {{ HOSTNAME_CFG01 }}
41 retry: {count: 1, delay: 5}
42 skip_fail: true
43
sgudz62df2fc2018-10-09 12:26:19 +030044{{ SHARED_OPENSTACK.MACRO_INSTALL_KEYSTONE() }}
Pavel Glazov6e9cbb92018-09-03 12:29:31 +040045
46{{ SHARED_OPENSTACK.MACRO_INSTALL_GLANCE() }}
47
48{{ SHARED_OPENSTACK.MACRO_INSTALL_NOVA() }}
49
50{{ SHARED_OPENSTACK.MACRO_INSTALL_CINDER() }}
51
52{{ SHARED_OPENSTACK.MACRO_INSTALL_NEUTRON() }}
53
54{{ SHARED_OPENSTACK.MACRO_INSTALL_HEAT() }}
55
56# install designate backend
57- description: Install powerdns
58 cmd: salt --hard-crash --state-output=mixed --state-verbose=False
59 -C 'I@powerdns:server' state.sls powerdns.server
60 node_name: {{ HOSTNAME_CFG01 }}
61 retry: {count: 1, delay: 5}
62 skip_fail: false
63
64{{ SHARED_OPENSTACK.MACRO_INSTALL_DESIGNATE() }}
65
66{{ SHARED_OPENSTACK.MACRO_INSTALL_HORIZON() }}
67
68# Install compute node
69
70- description: Apply formulas for compute node
71 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' state.apply
72 node_name: {{ HOSTNAME_CFG01 }}
73 retry: {count: 1, delay: 5}
74 skip_fail: true
75
76- description: Re-apply(as in doc) formulas for compute node
77 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' state.apply
78 node_name: {{ HOSTNAME_CFG01 }}
79 retry: {count: 1, delay: 5}
80 skip_fail: false
81
82- description: Check IP on computes
83 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'cmp*' cmd.run
84 'ip a'
85 node_name: {{ HOSTNAME_CFG01 }}
86 retry: {count: 10, delay: 30}
87 skip_fail: false
88
89
90 # Upload cirros image
91
92- description: Upload cirros image on ctl01
93 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
94 'wget http://images.mirantis.com.s3.amazonaws.com/cirros-x64-20170828.qcow2'
95 node_name: {{ HOSTNAME_CFG01 }}
96 retry: {count: 2, delay: 30}
97 skip_fail: false
98
99- description: Register image in glance
100 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
101 '. /root/keystonercv3; glance --timeout 120 image-create --name cirros --visibility public --disk-format qcow2 --container-format bare --progress < /root/cirros-x64-20170828.qcow2'
102 node_name: {{ HOSTNAME_CFG01 }}
103 retry: {count: 1, delay: 30}
104 skip_fail: false
105
106- description: Create net04_external
107 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
108 '. /root/keystonercv3; neutron net-create net04_ext --router:external True --provider:physical_network physnet1 --provider:network_type flat'
109 node_name: {{ HOSTNAME_CFG01 }}
110 retry: {count: 1, delay: 30}
111 skip_fail: false
112
113- description: Create subnet_external
114 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
115 '. /root/keystonercv3; neutron subnet-create net04_ext {{ IPV4_NET_EXTERNAL_PREFIX }}.0/24 --name net04_ext__subnet --disable-dhcp --allocation-pool start={{ IPV4_NET_EXTERNAL_PREFIX }}.150,end={{ IPV4_NET_EXTERNAL_PREFIX }}.180 --gateway {{ IPV4_NET_EXTERNAL_PREFIX }}.1'
116 node_name: {{ HOSTNAME_CFG01 }}
117 retry: {count: 1, delay: 30}
118 skip_fail: false
119
120- description: Create net04
121 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
122 '. /root/keystonercv3; neutron net-create net04'
123 node_name: {{ HOSTNAME_CFG01 }}
124 retry: {count: 1, delay: 30}
125 skip_fail: false
126
127- description: Create subnet_net04
128 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
129 '. /root/keystonercv3; neutron subnet-create net04 {{ IPV4_NET_TENANT_PREFIX }}.0/24 --name net04__subnet --allocation-pool start={{ IPV4_NET_TENANT_PREFIX }}.120,end={{ IPV4_NET_TENANT_PREFIX }}.240'
130 node_name: {{ HOSTNAME_CFG01 }}
131 retry: {count: 1, delay: 30}
132 skip_fail: false
133
134- description: Create router
135 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
136 '. /root/keystonercv3; neutron router-create net04_router01'
137 node_name: {{ HOSTNAME_CFG01 }}
138 retry: {count: 1, delay: 30}
139 skip_fail: false
140
141- description: Set gateway
142 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
143 '. /root/keystonercv3; neutron router-gateway-set net04_router01 net04_ext'
144 node_name: {{ HOSTNAME_CFG01 }}
145 retry: {count: 1, delay: 30}
146 skip_fail: false
147
148- description: Add interface
149 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
150 '. /root/keystonercv3; neutron router-interface-add net04_router01 net04__subnet'
151 node_name: {{ HOSTNAME_CFG01 }}
152 retry: {count: 1, delay: 30}
153 skip_fail: false
154
155- description: Allow all tcp
156 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
157 '. /root/keystonercv3; nova secgroup-add-rule default tcp 1 65535 0.0.0.0/0'
158 node_name: {{ HOSTNAME_CFG01 }}
159 retry: {count: 1, delay: 30}
160 skip_fail: false
161
162- description: Allow all icmp
163 cmd: salt --hard-crash --state-output=mixed --state-verbose=False 'ctl01*' cmd.run
164 '. /root/keystonercv3; nova secgroup-add-rule default icmp -1 -1 0.0.0.0/0'
165 node_name: {{ HOSTNAME_CFG01 }}
166 retry: {count: 1, delay: 30}
167 skip_fail: false
168
169- description: sync time
170 cmd: salt --hard-crash --state-output=mixed --state-verbose=False '*' cmd.run
171 'service ntp stop; ntpd -gq; service ntp start'
172 node_name: {{ HOSTNAME_CFG01 }}
173 retry: {count: 1, delay: 30}
174 skip_fail: false
175
Pavel Glazov78e6c592018-10-24 12:20:12 +0400176{{ SHARED.INSTALL_DOCKER_ON_GTW() }}
Pavel Glazov6e9cbb92018-09-03 12:29:31 +0400177
Pavel Glazov6e9cbb92018-09-03 12:29:31 +0400178- description: create rc file on cfg
179 cmd: scp ctl01:/root/keystonercv3 /root
180 node_name: {{ HOSTNAME_CFG01 }}
181 retry: {count: 1, delay: 30}
182 skip_fail: false
183
184- description: Copy rc file
185 cmd: scp /root/keystonercv3 gtw01:/root
186 node_name: {{ HOSTNAME_CFG01 }}
187 retry: {count: 1, delay: 30}
188 skip_fail: false