26 Commits

Author SHA1 Message Date
Jiri Stransky
20f614ba9a Ceph update and upgrade in config-download era
Correct playbook selection is now done automatically using
external_update_tasks and external_upgrade_tasks. The
CephAnsiblePlaybook is still usable and highest priority if set to
something else than the default. It can also be set to [] to
completely skip ceph-ansible playbook execution.

Closes-Bug: #1783949
Change-Id: If7955b31eda432dd61331281ad3d8f25a335fdfe
Depends-On: Ifdf5f1175849f79b98c76b4bcdef2a70f8f1fedb
2018-08-02 15:04:22 +02:00
Jiri Stransky
b82f743ab1 Drop obsolete environment for overcloud ceph-upgrade run
After switching from Heat workflow resources to external_deploy_tasks,
the `ceph-upgrade run` command no longer works and can be
dropped. Instead we'll be using `external-update run` and
`external-upgrade run` commands, which will not do stack update. It
will run Ansible and for Ceph specifically it will set the necessary
playbook directly via Ansible.

Partial-Bug: #1783949
Change-Id: I3490163bc426d070e245387201d64e07b908c74f
Depends-On: I228ce6228d0bd0bd4d40bc7a7cdd6bfe98a7a6ed
2018-08-02 15:04:22 +02:00
Zuul
ca16dd877c Merge "Update/upgrade prepare/converge in config-download era" 2018-07-31 21:50:38 +00:00
Jiri Stransky
39321cca71 Update/upgrade prepare/converge in config-download era
We inherit the `prepare` commands from deploy, in Rocky we will
automatically get config-download env file there so no need to
explicitly disable DeploymentSteps in *-prepare.yaml files too. We
should also disable the WorkflowSteps in config-download environment,
as they too aren't meant to be used with config-download.

Similarly, for `converge` commands in the *-converge.yaml files we
shouldn't re-enable the DeploymentSteps and WorkflowSteps, as that
would go against using config-download.

Change-Id: I89f54ba9a0a15afd26da4d4b26aba8ef09ebf04b
2018-07-17 20:01:12 +02:00
Lukas Bezdicka
1b6e061692 Fix GlanceRegistry FFU cleanup
Instead of nooping the service we need it to run in order to
remove if from the overcloud.

Change-Id: Ide061ca5e4495495658380499c62862e43441e25
Resolves: rhbz#1562199
Closes-Bug: #1775186
2018-06-05 15:25:26 +02:00
Zuul
97d6aa7b51 Merge "Ensure WorkflowSteps resource is enabled in ceph-upgrade-prepare" 2018-06-01 20:40:25 +00:00
Zuul
c099f863c9 Merge "Clear up Upgrade params on converge" 2018-06-01 17:43:57 +00:00
Giulio Fidente
ba8168fe96 Ensure WorkflowSteps resource is enabled in ceph-upgrade-prepare
To trigger ceph-ansible we need to make sure the WorkfowSteps
resource is enabled in ceph-upgrade-prepare env file.

Change-Id: Id760305971a68c397f9334265dd023b1e1884295
Closes-Bug: 1774647
2018-06-01 15:51:48 +02:00
Yurii Prokulevych
5df1d9d904 Unset UpgradeRemoveUnusedPackages on converge.
There is an option to remove package, if the service is being
disabled during upgrade. This option should be unset when running
'overcloud upgrade converge'.

Change-Id: I7bad96be0c3dfc1e605efe9d504249dc9045d71d
2018-05-30 11:00:13 +02:00
Emilien Macchi
e36cbb9524 Remove UpgradeRemoveUnusedPackages from undercloud-upgrade-prepare.yaml
We're creating a new parameter "undercloud_cleanup" in tripleoclient for
undercloud.conf, so our operators can cleanup the undercloud after an
upgrade.

Change-Id: I1b7a786cbf8171d1d89048b1a2524adec89b1267
2018-05-24 22:31:29 +00:00
Emilien Macchi
8ef2e7ee19 Add missing UndercloudUpgrade to environment
UndercloudUpgrade needs to be set to True when upgrading a containerized
undercloud. It was missed in a previous patch.

Change-Id: I5f06052b1d5290f8193aea57bafc8ddf86d2d8cf
2018-05-16 11:58:28 -07:00
Lukas Bezdicka
9757069cb3 Clear up Upgrade params on converge
During FFWD Upgrade or Minor Update we should still make sure
we clear Upgrade params too.

Resolves: rhbz#1558787
Closes-Bug: 1770191
Change-Id: Id1eb4c3d93ae8f36adb8ab4fa2df570a6a76951f
2018-05-14 15:08:27 +02:00
mandreou
d7ce2c8bb7 FFU Set NetworkDeploymentActions CREATE,UPDATE for ffwd-upgrade prepare
And unset back to CREATE on ffwd-upgrade converge. See [0] for more
discussion. This is to allow operators to update to the new script
based os-net-config network templates during the ffwd-upgrade.

[0] https://bugzilla.redhat.com/show_bug.cgi?id=1568561#c3
Change-Id: Ib5be49579545ad0ec7bf95e96fbe1f62ec4d3ac0
2018-05-12 12:19:58 +00:00
Zuul
fee920d897 Merge "Set normal CephAnsiblePlaybook on update/upgrade/ffwd converge" 2018-05-09 15:40:17 +00:00
Emilien Macchi
77aa6763f6 Undercloud upgrades will use upgrade_tasks
Instead of using host_prep_tasks (which are part of deployment tasks),
we'll use the upgrade tasks that are now well known and tested in
previous releases, when the we containerized the overcloud.

Depends-On: Id25e6280b4b4f060d5e3f78a50ff83aaca9e6b1a
Change-Id: Ic199c7d431e155e2d37996acd0d7b924d14af2b7
2018-05-05 06:52:34 +00:00
Jiri Stransky
4742f2ed5a Set normal CephAnsiblePlaybook on update/upgrade/ffwd converge
As we discovered bug #1768586 we'll need to make sure that every
parameter tweak in plan is followed by a stack update.

So far the Ceph upgrade command did set param -> stack update -> unset
param (only in plan). However this means the last CephAnsiblePlaybook
setting (back to normal deploy playbook) was discarded.

Let's reuse normal converge commands to converge CephAnsiblePlaybook
too, and we can remove the (now unused) ceph-upgrade-converge.yaml. We
won't do more stack updates than necessary, and at the same time the
user workflow stays somewhat consistent between envs that do and don't
have Ceph.

An alternative would be to run the as part of the Ceph command, but
that either means we'd have to run one more stack update then
necessary, or skip the last converge in envs with Ceph, and
essentially diverge further from the non-Ceph workflow.

Change-Id: If596531cbb1e750ed67e66391743f4c1833e4337
Depends-On: I025eac40f8bda5f23c789e7fef1a9e9b49947f66
Partial-Bug: #1768586
2018-05-04 11:34:23 +02:00
Zuul
108706e37f Merge "Ensure config-download mappings are unset on ceph-upgrade" 2018-05-03 16:57:34 +00:00
Zuul
a2cf9be58a Merge "Introduce Ceph upgrade environments" 2018-05-03 16:53:16 +00:00
Giulio Fidente
fc9d9ee493 Ensure config-download mappings are unset on ceph-upgrade
Purpose is to ensure that any mapping previously used to enable
config-download is reset to perform a regular Heat stack update on
ceph-upgrade. We may need to do "update/upgrade/ffwd -> ceph ->
converge" instead of the previously assumed "update/upgrade/ffwd ->
converge -> ceph".

This also removes the no-op of DeploymentSteps -- we need them enabled
during Ceph upgrade as we need firewall rules applied.

Co-Authored-By: Jiri Stransky <jistr@redhat.com>
Closes-Bug: #1767318
Related-Bug: #1767317
Change-Id: I52312ffcd438c354872ab3c74138b47ae71aab4b
2018-04-27 11:55:58 +02:00
Zuul
cfc4126af2 Merge "No-op Mistral workflow resources for update/upgrade/ffwd" 2018-04-25 04:53:30 +00:00
Lukas Bezdicka
6730accc63 Introduce Ceph upgrade environments
These will disable OS::TripleO::DeploymentSteps on prepare, to allow
for a Heat stack update without triggering a puppet apply and then
restore the Heat resource and the Ceph ansible playbook on converge.

Change-Id: Ie765b429c4cb36d9dd616584cc1d4f45184fa1b8
2018-04-24 09:01:39 +00:00
Jiri Stransky
19be98ba07 No-op Mistral workflow resources for update/upgrade/ffwd
So far we haven't been disabling workflows for update/upgrade. We
should disable them by default as they could have the potential to
disrupt the update/upgrade/ffwd procedure.

The main example of a thing we deploy via the workflow resources is
Ceph. We decided no-opping ceph-ansible for the main
update/upgrade/ffwd upgrade steps is the safest path forward and we'll
update/upgrade Ceph it after the main procedure is finished.


Change-Id: I34c7213ab7b70963ad2e50f7633b665fad70bde5
2018-04-23 10:47:58 +00:00
Jose Luis Franco Arza
3ed0be0a1f Disable FluentClient service for ffwd/upgrades.
FluentClient service has been renamed
into Fluentd [0] for queens. This patch
handles the disabling of the old FluentdClient
service.

[0] Idb9886f04d56ffc75a78c4059ff319b58b4acf9f

Change-Id: I085973f3d23fd78c16cba94a91692421956b301b
Closes-Bug: #1746493
2018-04-17 17:16:44 +02:00
mandreou
19ed1afb2a Update environment files for Q upgrade and ffwd upgrade
This consolidates the upgrade and ffwd-upgrade related env files,
removing no longer relevant files (like converge vs converge-docker).

In line with recent/ongoing work in tripleoclient [1][2] we now have
cli: overcloud [upgrade|update|ffwd-upgrade] [prepare|run|converge]

With this patch we can also change the set/unset of resource 'noop'
and move it from tripleo-common to python-tripleoclient, like I am
pointing at in related client review below. If others agree then I
will do the same with the upgrade-prepare and also the ffwd cli
in [3], i.e. add explicit inclusion of the upgrade-prepare.yaml
and then similarly include the upgrade-converge.yaml for the
upgrade/ffwd-upgrade converge cli.

Related:
  I1288fe68ae8af02a5d77390d237ec467d88e43d2 python-tripleoclient

[1] 96ffa3a325
[2] https://review.openstack.org/#/c/558536/5/tripleoclient/v1/overcloud_update.py
[3] https://review.openstack.org/#/c/557937/4/tripleoclient/v1/overcloud_ffwd_upgrade.py@72

Change-Id: Icfe494e3219d6d6cd3251f75bb4329fc4d793c3c
2018-04-16 08:14:17 +00:00
Emilien Macchi
d86025593b Handle undercloud upgrades via host_prep_tasks
Using host_prep_tasks interface to handle undercloud teardown before we
run the undercloud install.
The reason of not using upgrade_tasks is because the existing tasks were
created for the overcloud upgrade first and there are too much logic
right now so we can easily re-use the bits for the undercloud. In the
future, we'll probably use upgrade_tasks for both the undercloud and
overcloud but right now this is not possible and a simple way to move
forward was to implement these tasks that work fine for the undercloud
containerization case.

Workflow will be:
- Services will be stopped and disabled (except mariadb)
- Neutron DB will be renamed, then mariadb stopped & disabled
- Remove cron jobs
- All packages will be upgraded with yum update.

Change-Id: I36be7f398dcd91e332687c6222b3ccbb9cd74ad2
2018-04-12 18:14:28 -07:00
Jiri Stransky
6f9c97fc85 Add prepare/converge env files for update
These will be automatically pulled in by the client.

Change-Id: I486ad0d44f105a6fa9fd24dcf7ac28d40ceecc27
2018-04-06 14:36:52 +02:00