1 {% set enabled_roles = roles|rejectattr('disable_upgrade_deployment')|list -%}
2 {% set batch_upgrade_steps_max = 3 -%}
3 {% set upgrade_steps_max = 6 -%}
4 {% set deliver_script = {'deliver': False} -%}
5 heat_template_version: pike
6 description: 'Upgrade steps for all roles'
13 description: Name of the topmost stack
16 description: Mapping of Role name e.g Controller to the per-role data
22 Setting to a previously unused value during stack-update will trigger
23 the Upgrade resources to re-run on all roles.
26 description: Mapping of service endpoint -> protocol. Typically set
27 via parameter_defaults in the resource registry.
32 description: Keystone region for endpoint
34 description: The password for the nova service and db account, used by nova-api.
40 {% for role in roles if role.disable_upgrade_deployment|default(false) %}
41 {{role.name}}DeliverUpgradeScriptConfig:
42 type: OS::Heat::SoftwareConfig
54 ROLE_NAME: {{role.name}}
55 - get_file: ../extraconfig/tasks/pacemaker_common_functions.sh
56 - get_file: ../extraconfig/tasks/run_puppet.sh
57 - get_file: ../extraconfig/tasks/tripleo_upgrade_node.sh
59 {{role.name}}DeliverUpgradeScriptDeployment:
60 type: OS::Heat::SoftwareDeploymentGroup
62 servers: {get_param: [servers, {{role.name}}]}
63 config: {get_resource: {{role.name}}DeliverUpgradeScriptConfig}
66 # Upgrade Steps for all roles, batched updates
67 # The UpgradeConfig resources could actually be created without
68 # serialization, but the event output is easier to follow if we
69 # do, and there should be minimal performance hit (creating the
70 # config is cheap compared to the time to apply the deployment).
71 {% for step in range(0, batch_upgrade_steps_max) %}
72 # Batch config resources step {{step}}
73 {%- for role in roles %}
74 {{role.name}}UpgradeBatchConfig_Step{{step}}:
75 type: OS::TripleO::UpgradeConfig
78 {%- for role_inside in enabled_roles %}
79 - {{role_inside.name}}UpgradeBatch_Step{{step -1}}
82 {% for role in roles if role.disable_upgrade_deployment|default(false) %}
83 {% if deliver_script.update({'deliver': True}) %} {% endif %}
85 {% if deliver_script.deliver %}
87 {% for dep in roles if dep.disable_upgrade_deployment|default(false) %}
88 - {{dep.name}}DeliverUpgradeScriptDeployment
93 UpgradeStepConfig: {get_param: [role_data, {{role.name}}, upgrade_batch_tasks]}
97 # Batch deployment resources for step {{step}} (only for enabled roles)
98 {%- for role in enabled_roles %}
99 {{role.name}}UpgradeBatch_Step{{step}}:
100 type: OS::Heat::SoftwareDeploymentGroup
103 {%- for role_inside in enabled_roles %}
104 - {{role_inside.name}}UpgradeBatch_Step{{step -1}}
107 {% for role in roles if role.disable_upgrade_deployment|default(false) %}
108 {% if deliver_script.update({'deliver': True}) %} {% endif %}
110 {% if deliver_script.deliver %}
112 {% for dep in roles if dep.disable_upgrade_deployment|default(false) %}
113 - {{dep.name}}DeliverUpgradeScriptDeployment
119 max_batch_size: {{role.upgrade_batch_size|default(1)}}
121 max_batch_size: {{role.upgrade_batch_size|default(1)}}
123 servers: {get_param: [servers, {{role.name}}]}
124 config: {get_resource: {{role.name}}UpgradeBatchConfig_Step{{step}}}
127 update_identifier: {get_param: UpdateIdentifier}
131 # Dump the puppet manifests to be apply later when disable_upgrade_deployment
133 {% for role in roles if role.disable_upgrade_deployment|default(false) %}
134 {{role.name}}DeliverPuppetConfig:
135 type: OS::Heat::SoftwareConfig
144 cat > /root/{{role.name}}_puppet_config.pp << ENDOFCAT
148 PUPPET_CLASSES: {get_param: [role_data, {{role.name}}, step_config]}
150 {{role.name}}DeliverPuppetDeployment:
151 type: OS::Heat::SoftwareDeploymentGroup
153 servers: {get_param: [servers, {{role.name}}]}
154 config: {get_resource: {{role.name}}DeliverPuppetConfig}
157 # Upgrade Steps for all roles
158 {%- for step in range(0, upgrade_steps_max) %}
159 # Config resources for step {{step}}
160 {%- for role in roles %}
161 {{role.name}}UpgradeConfig_Step{{step}}:
162 type: OS::TripleO::UpgradeConfig
163 # The UpgradeConfig resources could actually be created without
164 # serialization, but the event output is easier to follow if we
165 # do, and there should be minimal performance hit (creating the
166 # config is cheap compared to the time to apply the deployment).
168 {%- for role_inside in enabled_roles %}
170 - {{role_inside.name}}Upgrade_Step{{step -1}}
172 - {{role_inside.name}}UpgradeBatch_Step{{batch_upgrade_steps_max -1}}
176 UpgradeStepConfig: {get_param: [role_data, {{role.name}}, upgrade_tasks]}
180 # Deployment resources for step {{step}} (only for enabled roles)
181 {%- for role in enabled_roles %}
182 {{role.name}}Upgrade_Step{{step}}:
183 type: OS::Heat::SoftwareDeploymentGroup
185 {%- for role_inside in enabled_roles %}
187 - {{role_inside.name}}Upgrade_Step{{step -1}}
189 - {{role_inside.name}}UpgradeBatch_Step{{batch_upgrade_steps_max -1}}
193 servers: {get_param: [servers, {{role.name}}]}
194 config: {get_resource: {{role.name}}UpgradeConfig_Step{{step}}}
197 update_identifier: {get_param: UpdateIdentifier}
201 # Post upgrade deployment steps for all roles
202 # This runs the normal configuration (e.g puppet) steps unless upgrade
203 # is disabled for the role
204 AllNodesPostUpgradeSteps:
205 type: OS::TripleO::PostUpgradeSteps
207 {%- for dep in enabled_roles %}
208 - {{dep.name}}Upgrade_Step{{upgrade_steps_max - 1}}
211 servers: {get_param: servers}
212 stack_name: {get_param: stack_name}
213 role_data: {get_param: role_data}
214 ctlplane_service_ips: {get_param: ctlplane_service_ips}
217 # Output the config for each role, just use Step1 as the config should be
218 # the same for all steps (only the tag provided differs)
220 description: The per-role upgrade configuration used
222 {% for role in roles %}
223 {{role.name.lower()}}: {get_attr: [{{role.name}}UpgradeConfig_Step1, upgrade_config]}