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
23 Setting to a previously unused value during stack-update will trigger
24 the Upgrade resources to re-run on all roles.
27 description: Mapping of service endpoint -> protocol. Typically set
28 via parameter_defaults in the resource registry.
33 description: Keystone region for endpoint
35 description: The password for the nova service and db account
41 {% for role in roles if role.disable_upgrade_deployment|default(false) %}
42 {{role.name}}DeliverUpgradeScriptConfig:
43 type: OS::Heat::SoftwareConfig
55 ROLE_NAME: {{role.name}}
56 - get_file: ../extraconfig/tasks/pacemaker_common_functions.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 # Upgrade Steps for all roles
132 {%- for step in range(0, upgrade_steps_max) %}
133 # Config resources for step {{step}}
134 {%- for role in roles %}
135 {{role.name}}UpgradeConfig_Step{{step}}:
136 type: OS::TripleO::UpgradeConfig
137 # The UpgradeConfig resources could actually be created without
138 # serialization, but the event output is easier to follow if we
139 # do, and there should be minimal performance hit (creating the
140 # config is cheap compared to the time to apply the deployment).
142 {%- for role_inside in enabled_roles %}
144 - {{role_inside.name}}Upgrade_Step{{step -1}}
146 - {{role_inside.name}}UpgradeBatch_Step{{batch_upgrade_steps_max -1}}
150 UpgradeStepConfig: {get_param: [role_data, {{role.name}}, upgrade_tasks]}
154 # Deployment resources for step {{step}} (only for enabled roles)
155 {%- for role in enabled_roles %}
156 {{role.name}}Upgrade_Step{{step}}:
157 type: OS::Heat::SoftwareDeploymentGroup
159 {%- for role_inside in enabled_roles %}
161 - {{role_inside.name}}Upgrade_Step{{step -1}}
163 - {{role_inside.name}}UpgradeBatch_Step{{batch_upgrade_steps_max -1}}
167 servers: {get_param: [servers, {{role.name}}]}
168 config: {get_resource: {{role.name}}UpgradeConfig_Step{{step}}}
171 update_identifier: {get_param: UpdateIdentifier}
175 # Post upgrade deployment steps for all roles
176 # This runs the normal configuration (e.g puppet) steps unless upgrade
177 # is disabled for the role
178 AllNodesPostUpgradeSteps:
179 type: OS::TripleO::PostUpgradeSteps
181 {%- for dep in enabled_roles %}
182 - {{dep.name}}Upgrade_Step{{upgrade_steps_max - 1}}
185 servers: {get_param: servers}
186 stack_name: {get_param: stack_name}
187 role_data: {get_param: role_data}
188 ctlplane_service_ips: {get_param: ctlplane_service_ips}
190 {%- for step in range(0, upgrade_steps_max) %}
191 {%- for role in roles %}
192 {{role.name}}PostUpgradeConfig_Config{{step}}:
193 type: OS::TripleO::UpgradeConfig
195 {%- for role_inside in enabled_roles %}
197 - {{role_inside.name}}PostUpgradeConfig_Deployment{{step -1}}
199 - AllNodesPostUpgradeSteps
203 UpgradeStepConfig: {get_param: [role_data, {{role.name}}, post_upgrade_tasks]}
207 {%- for role in enabled_roles %}
208 {{role.name}}PostUpgradeConfig_Deployment{{step}}:
209 type: OS::Heat::SoftwareDeploymentGroup
211 {%- for role_inside in enabled_roles %}
213 - {{role_inside.name}}PostUpgradeConfig_Deployment{{step -1}}
215 - AllNodesPostUpgradeSteps
219 servers: {get_param: [servers, {{role.name}}]}
220 config: {get_resource: {{role.name}}PostUpgradeConfig_Config{{step}}}
223 update_identifier: {get_param: UpdateIdentifier}
228 # Output the config for each role, just use Step1 as the config should be
229 # the same for all steps (only the tag provided differs)
231 description: The per-role upgrade configuration used
233 {% for role in roles %}
234 {{role.name.lower()}}: {get_attr: [{{role.name}}UpgradeConfig_Step1, upgrade_config]}
237 description: Mapping of config data for all roles
238 value: {get_attr: [AllNodesPostUpgradeSteps, RoleConfig]}