Unfortunately, there will always be some cases where OpenShift fails to install properly. In these events, it is helpful to understand the likely failure modes as well as how to troubleshoot the failure.
This document discusses some troubleshooting options for OpenStack based deployments. For general tips on troubleshooting the installer, see the Installer Troubleshooting guide.
OpenStack CLI tools should be installed, then:
openstack console log show <instance>
This could be because the machine's instance was accidentally destroyed and the cluster API provider cannot recreate it.
You can check the status of machines with the help of the command
oc get machines -n openshift-machine-api
If the broken machine is a master then follow the instructions in the disaster recovery documentation.
For workers, you should delete the machine manually with
oc delete machine -n openshift-machine-api <machine_name>
The operation can take up to 5 minutes, during which time the machine will be gracefully removed and all its resources returned to the pool.
A new worker machine for the cluster will soon be created automatically by the machine-api-operator.
NOTE: in future versions of OpenShift all broken machines will be automatically deleted and recovered by the machine-api-operator.
Get the IP address of the node on the private network:
openstack server list | grep master
| 0dcd756b-ad80-42f1-987a-1451b1ae95ba | cluster-wbzrr-master-1 | ACTIVE | cluster-wbzrr-openshift=172.24.0.21 | rhcos | m1.s2.xlarge |
| 3b455e43-729b-4e64-b3bd-1d4da9996f27 | cluster-wbzrr-master-2 | ACTIVE | cluster-wbzrr-openshift=172.24.0.18 | rhcos | m1.s2.xlarge |
| 775898c3-ecc2-41a4-b98b-a4cd5ae56fd0 | cluster-wbzrr-master-0 | ACTIVE | cluster-wbzrr-openshift=172.24.0.12 | rhcos | m1.s2.xlarge |
And connect to it using the master currently holding the API VIP (and hence the API FIP) as a jumpbox:
ssh -J core@${FIP} core@<host>
When deploying a cluster, the installer generates metadata in the asset directory that is then used to destroy the cluster. If the metadata were accidentally deleted, the destruction of the cluster terminates with an error
FATAL Failed while preparing to destroy cluster: open clustername/metadata.json: no such file or directory
To avoid this error and successfully destroy the cluster, you need to restore the metadata.json
file in a temporary asset directory. To do this, you only need to know ID of the cluster you want to destroy.
First, you need to create a temporary directory where the metadata.json
file will be located. The name and location can be anything, but to avoid possible conflicts, we recommend using mktemp
command.
export TMP_DIR=$(mktemp -d -t shiftstack-XXXXXXXXXX)
The next step is to restore the metadata.json
file.
export CLUSTER_ID=clustername-eiu38 # id of the cluster you want to destroy
echo "{\"infraID\":\"$INFRA_ID\",\"openstack\":{\"identifier\":{\"openshiftClusterID\":\"$INFRA_ID\"}}}" > $TMP_DIR/metadata.json
Now you have a working directory and you can destroy the cluster by executing the following command:
openshift-install destroy cluster --dir $TMP_DIR