Follow these steps to back up etcd data by creating an etcd snapshot and backing up the resources for the static Pods. This backup can be saved and used at a later time if you need to restore etcd.
Important
|
Only save a backup from a single master host. Do not take a backup from each master host in the cluster. |
-
SSH access to a master host.
-
Access a master host.
-
If the cluster-wide proxy is enabled, be sure that you have exported the
NO_PROXY
,HTTP_PROXY
, andHTTPS_PROXY
environment variables.TipYou can check whether the proxy is enabled by reviewing the output of
oc get proxy cluster -o yaml
. The proxy is enabled if thehttpProxy
,httpsProxy
, andnoProxy
fields have values set. -
Run the
cluster-backup.sh
script and pass in the location to save the backup to.Be sure to pass in the
-E
flag tosudo
so that environment variables are properly passed to the script.$ sudo -E /usr/local/bin/cluster-backup.sh ./assets/backup 1bf371f1b5a483927cd01bb593b0e12cff406eb8d7d0acf4ab079c36a0abd3f7 etcdctl version: 3.3.18 API version: 3.3 found latest kube-apiserver-pod: /etc/kubernetes/static-pod-resources/kube-apiserver-pod-7 found latest kube-controller-manager-pod: /etc/kubernetes/static-pod-resources/kube-controller-manager-pod-8 found latest kube-scheduler-pod: /etc/kubernetes/static-pod-resources/kube-scheduler-pod-6 found latest etcd-pod: /etc/kubernetes/static-pod-resources/etcd-pod-2 Snapshot saved at /var/home/core/assets/backup/snapshot_2020-03-18_220218.db snapshot db and kube resources are successfully saved to /var/home/core/assets/backup
In this example, two files are created in the
./assets/backup/
directory on the master host:-
snapshot_<datetimestamp>.db
: This file is the etcd snapshot. -
static_kuberesources_<datetimestamp>.tar.gz
: This file contains the resources for the static Pods. If etcd encryption is enabled, it also contains the encryption keys for the etcd snapshot.NoteIf etcd encryption is enabled, it is recommended to store this second file separately from the etcd snapshot for security reasons. However, this file is required in order to restore from the etcd snapshot.
Keep in mind that etcd encryption only encrypts values, not keys. This means that resource types, namespaces, and object names are unencrypted.
-