This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 6. Downgrading OpenShift
6.1. Overview
Following an OpenShift Container Platform upgrade, it may be desirable in extreme cases to downgrade your cluster to a previous version. The following sections outline the required steps for each system in a cluster to perform such a downgrade for the OpenShift Container Platform 3.5 to 3.4 downgrade path.
These steps are currently only supported for RPM-based installations of OpenShift Container Platform and assumes downtime of the entire cluster.
6.2. Verifying Backups
The Ansible playbook used during the upgrade process should have created a backup of the master-config.yaml file and the etcd data directory. Ensure these exist on your masters and etcd members:
/etc/origin/master/master-config.yaml.<timestamp> /var/lib/origin/etcd-backup-<timestamp>
/etc/origin/master/master-config.yaml.<timestamp>
/var/lib/origin/etcd-backup-<timestamp>Also, back up the node-config.yaml file on each node (including masters, which have the node component on them) with a timestamp:
/etc/origin/node/node-config.yaml.<timestamp>
/etc/origin/node/node-config.yaml.<timestamp>If you use a separate etcd cluster instead of a single embedded etcd instance, the backup is likely created on all etcd members, though only one is required for the recovery process. You can run a separate etcd instance that is co-located with your master nodes.
The RPM downgrade process in a later step should create .rpmsave backups of the following files, but it may be a good idea to keep a separate copy regardless:
/etc/sysconfig/atomic-openshift-master /etc/etcd/etcd.conf
/etc/sysconfig/atomic-openshift-master
/etc/etcd/etcd.conf - 1
- Only required if using a separate etcd cluster.
6.3. Shutting Down the Cluster
On all masters, nodes, and etcd members, if you use a separate etcd cluster that runs on different nodes, ensure the relevant services are stopped.
On the master in a single master cluster:
systemctl stop atomic-openshift-master
# systemctl stop atomic-openshift-masterOn each master in a multi-master cluster:
systemctl stop atomic-openshift-master-api systemctl stop atomic-openshift-master-controllers
# systemctl stop atomic-openshift-master-api
# systemctl stop atomic-openshift-master-controllersOn all master and node hosts:
systemctl stop atomic-openshift-node
# systemctl stop atomic-openshift-nodeOn any etcd hosts for a separate etcd cluster:
systemctl stop etcd
# systemctl stop etcd6.4. Removing RPMs
- The *-excluder packages add entries to the exclude directive in the host’s /etc/yum.conf file when installed. Run the following command on each host to remove the - atomic-openshift-*and- dockerpackages from the exclude list:- atomic-openshift-excluder unexclude atomic-openshift-docker-excluder unexclude - # atomic-openshift-excluder unexclude # atomic-openshift-docker-excluder unexclude- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- On all masters, nodes, and etcd members, if you use a separate etcd cluster that runs on different nodes, remove the following packages: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If you use a separate etcd cluster, also remove the etcd package: - yum remove etcd - # yum remove etcd- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If using the embedded etcd, leave the etcd package installed. It is required for running the - etcdctlcommand to issue operations in later steps.
6.5. Downgrading Docker
Both OpenShift Container Platform 3.4 and 3.5 require Docker 1.12, so Docker does not need to be downgraded.
6.6. Reinstalling RPMs
Disable the OpenShift Container Platform 3.5 repositories, and re-enable the 3.4 repositories:
subscription-manager repos \
    --disable=rhel-7-server-ose-3.5-rpms \
    --enable=rhel-7-server-ose-3.4-rpms
# subscription-manager repos \
    --disable=rhel-7-server-ose-3.5-rpms \
    --enable=rhel-7-server-ose-3.4-rpmsOn each master, install the following packages:
On each node, install the following packages:
If you use a separate etcd cluster, install the following package on each etcd member:
yum install etcd
# yum install etcd6.7. Restoring etcd
See Backup and Restore.
6.8. Bringing OpenShift Container Platform Services Back Online
See Backup and Restore.
6.9. Verifying the Downgrade
- To verify the downgrade, first check that all nodes are marked as Ready: - oc get nodes - # oc get nodes NAME STATUS AGE master.example.com Ready,SchedulingDisabled 165d node1.example.com Ready 165d node2.example.com Ready 165d- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Then, verify that you are running the expected versions of the docker-registry and router images, if deployed: - oc get -n default dc/docker-registry -o json | grep \"image\" oc get -n default dc/router -o json | grep \"image\" - # oc get -n default dc/docker-registry -o json | grep \"image\" "image": "openshift3/ose-docker-registry:v3.4.1.37-2", # oc get -n default dc/router -o json | grep \"image\" "image": "openshift3/ose-haproxy-router:v3.4.1.37-2",- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- You can use the diagnostics tool on the master to look for common issues and provide suggestions: - oc adm diagnostics - # oc adm diagnostics ... [Note] Summary of diagnostics execution: [Note] Completed with no errors or warnings seen.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow