이 콘텐츠는 선택한 언어로 제공되지 않습니다.
Chapter 9. Deploying on OpenStack with rootVolume and etcd on local disk
As a day 2 operation, you can resolve and prevent performance issues of your Red Hat OpenStack Platform (RHOSP) installation by moving etcd from a root volume (provided by OpenStack Cinder) to a dedicated ephemeral local disk.
9.1. Deploying RHOSP on local disk
If you have an existing RHOSP cloud, you can move etcd from that cloud to a dedicated ephemeral local disk.
Prerequisites
- You have an OpenStack cloud with a working Cinder.
- Your OpenStack cloud has at least 75 GB of available storage to accommodate 3 root volumes for the OpenShift control plane.
- 
						The OpenStack cloud is deployed with Nova ephemeral storage that uses a local storage backend and not rbd.
Procedure
- Create a Nova flavor for the control plane with at least 10 GB of ephemeral disk by running the following command, replacing the values for - --ram,- --disk, and <flavor_name> based on your environment:- openstack flavor create --<ram 16384> --<disk 0> --ephemeral 10 --vcpus 4 <flavor_name> - $ openstack flavor create --<ram 16384> --<disk 0> --ephemeral 10 --vcpus 4 <flavor_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Deploy a cluster with root volumes for the control plane; for example: - Example YAML file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Deploy the cluster you created by running the following command: - openshift-install create cluster --dir <installation_directory> - $ openshift-install create cluster --dir <installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the location of the customized./install-config.yaml filethat you previously created.
 
- Verify that the cluster you deployed is healthy before proceeding to the next step by running the following command: - oc wait clusteroperators --all --for=condition=Progressing=false - $ oc wait clusteroperators --all --for=condition=Progressing=false- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Ensures that the cluster operators are finished progressing and that the cluster is not deploying or updating.
 
- Create a file named - 98-var-lib-etcd.yamlby using the following YAML file:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The etcd database must be mounted by the device, not a label, to ensure thatsystemdgenerates the device dependency used in this config to trigger filesystem creation.
- 2
- Do not run if the file systemdev/disk/by-label/local-etcdalready exists.
- 3
- Fails with an alert message if/dev/disk/by-label/ephemeral0does not exist.
- 4
- Migrates existing data to local etcd database. This config does so after/var/lib/etcdis mounted, but before CRI-O starts so etcd is not running yet.
- 5
- Requires that etcd is mounted and does not contain a member directory, but the ostree does.
- 6
- Cleans up any previous migration state.
- 7
- Copies and moves in separate steps to ensure atomic creation of a complete member directory.
- 8
- Performs a quick check of the mount point directory before performing a full recursive relabel. If restorecon in the file path/var/lib/etcdcannot rename the directory, the recursive rename is not performed.
 Warning- After you apply the - 98-var-lib-etcd.yamlfile to the system, do not remove it. Removing this file will break etcd members and lead to system instability.- If a rollback is necessary, modify the - ControlPlaneMachineSetobject to use a flavor that does not include ephemeral disks. This change regenerates the control plane nodes without using ephemeral disks for the etcd partition, which avoids issues related to the- 98-var-lib-etcd.yamlfile. It is safe to remove the- 98-var-lib-etcd.yamlfile only after the update to the- ControlPlaneMachineSetobject is complete and no control plane nodes are using ephemeral disks.
- Create the new - MachineConfigobject by running the following command:- oc create -f 98-var-lib-etcd.yaml - $ oc create -f 98-var-lib-etcd.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- Moving the etcd database onto the local disk of each control plane machine takes time. 
- Verify that the etcd databases has been transferred to the local disk of each control plane by running the following commands: - Verify that the cluster is still updating by running the following command: - oc wait --timeout=45m --for=condition=Updating=false machineconfigpool/master - $ oc wait --timeout=45m --for=condition=Updating=false machineconfigpool/master- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the cluster is ready by running the following command: - oc wait node --selector='node-role.kubernetes.io/master' --for condition=Ready --timeout=30s - $ oc wait node --selector='node-role.kubernetes.io/master' --for condition=Ready --timeout=30s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the cluster Operators are running in the cluster by running the following command: - oc wait clusteroperators --timeout=30m --all --for=condition=Progressing=false - $ oc wait clusteroperators --timeout=30m --all --for=condition=Progressing=false- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow