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.Este conteúdo não está disponível no idioma selecionado.
Chapter 4. OADP Application backup and restore
4.1. Introduction to OpenShift API for Data Protection
The OpenShift API for Data Protection (OADP) product safeguards customer applications on OpenShift Container Platform. It offers comprehensive disaster recovery protection, covering OpenShift Container Platform applications, application-related cluster resources, persistent volumes, and internal images. OADP is also capable of backing up both containerized applications and virtual machines (VMs).
However, OADP does not serve as a disaster recovery solution for etcd or OpenShift Operators.
4.1.1. OpenShift API for Data Protection APIs
OpenShift API for Data Protection (OADP) provides APIs that enable multiple approaches to customizing backups and preventing the inclusion of unnecessary or inappropriate resources.
OADP provides the following APIs:
4.2. OADP release notes
The release notes for OpenShift API for Data Protection (OADP) describe new features and enhancements, deprecated features, product recommendations, known issues, and resolved issues.
4.2.1. OADP 1.2.3 release notes
4.2.1.1. New features
There are no new features in the release of OpenShift API for Data Protection (OADP) 1.2.3.
4.2.1.2. Resolved issues
The following highlighted issues are resolved in OADP 1.2.3:
Multiple HTTP/2 enabled web servers are vulnerable to a DDoS attack (Rapid Reset Attack)
In previous releases of OADP 1.2, the HTTP/2 protocol was susceptible to a denial of service attack because request cancellation could reset multiple streams quickly. The server had to set up and tear down the streams while not hitting any server-side limit for the maximum number of active streams per connection. This resulted in a denial of service due to server resource consumption. For a list of all OADP issues associated with this CVE, see the following Jira list.
For more information, see CVE-2023-39325 (Rapid Reset Attack).
For a complete list of all issues resolved in the release of OADP 1.2.3, see the list of OADP 1.2.3 resolved issues in Jira.
4.2.1.3. Known issues
There are no known issues in the release of OADP 1.2.3.
4.2.2. OADP 1.2.2 release notes
4.2.2.1. New features
There are no new features in the release of OpenShift API for Data Protection (OADP) 1.2.2.
4.2.2.2. Resolved issues
The following highlighted issues are resolved in OADP 1.2.2:
Restic restore partially failed due to a Pod Security standard
In previous releases of OADP 1.2, OpenShift Container Platform 4.14 enforced a pod security admission (PSA) policy that hindered the readiness of pods during a Restic restore process.
This issue has been resolved in the release of OADP 1.2.2, and also OADP 1.1.6. Therefore, it is recommended that users upgrade to these releases.
For more information, see Restic restore partially failing on OCP 4.14 due to changed PSA policy. (OADP-2094)
Backup of an app with internal images partially failed with plugin panicked error
In previous releases of OADP 1.2, the backup of an application with internal images partially failed with plugin panicked error returned. The backup partially fails with this error in the Velero logs:
time="2022-11-23T15:40:46Z" level=info msg="1 errors encountered backup up item" backup=openshift-adp/django-persistent-67a5b83d-6b44-11ed-9cba-902e163f806c logSource="/remote-source/velero/app/pkg/backup/backup.go:413" name=django-psql-persistent time="2022-11-23T15:40:46Z" level=error msg="Error backing up item" backup=openshift-adp/django-persistent-67a5b83d-6b44-11ed-9cba-902e163f8
time="2022-11-23T15:40:46Z" level=info msg="1 errors encountered backup up item" backup=openshift-adp/django-persistent-67a5b83d-6b44-11ed-9cba-902e163f806c logSource="/remote-source/velero/app/pkg/backup/backup.go:413" name=django-psql-persistent
time="2022-11-23T15:40:46Z" level=error msg="Error backing up item" backup=openshift-adp/django-persistent-67a5b83d-6b44-11ed-9cba-902e163f8This issue has been resolved in OADP 1.2.2. (OADP-1057).
ACM cluster restore was not functioning as expected due to restore order
In previous releases of OADP 1.2, ACM cluster restore was not functioning as expected due to restore order. ACM applications were removed and re-created on managed clusters after restore activation. (OADP-2505)
VM’s using filesystemOverhead failed when backing up and restoring due to volume size mismatch
In previous releases of OADP 1.2, due to storage provider implementation choices, whenever there was a difference between the application persistent volume claims (PVCs) storage request and the snapshot size of the same PVC, VM’s using filesystemOverhead failed when backing up and restoring. This issue has been resolved in the Data Mover of OADP 1.2.2. (OADP-2144)
OADP did not contain an option to set VolSync replication source prune interval
							In previous releases of OADP 1.2, there was no option to set the VolSync replication source pruneInterval. (OADP-2052)
						
Possible pod volume backup failure if Velero was installed in multiple namespaces
In previous releases of OADP 1.2, there was a possibility of pod volume backup failure if Velero was installed in multiple namespaces. (OADP-2409)
Backup Storage Locations moved to unavailable phase when VSL uses custom secret
In previous releases of OADP 1.2, Backup Storage Locations moved to unavailable phase when Volume Snapshot Location used custom secret. (OADP-1737)
For a complete list of all issues resolved in the release of OADP 1.2.2, see the list of OADP 1.2.2 resolved issues in Jira.
4.2.2.3. Known issues
The following issues have been highlighted as known issues in the release of OADP 1.2.2:
Must-gather command fails to remove ClusterRoleBinding resources
							The oc adm must-gather command fails to remove ClusterRoleBinding resources, which are left on cluster due to admission webhook. Therefore, requests for the removal of the ClusterRoleBinding resources are denied. (OADP-27730)
						
admission webhook "clusterrolebindings-validation.managed.openshift.io" denied the request: Deleting ClusterRoleBinding must-gather-p7vwj is not allowed
admission webhook "clusterrolebindings-validation.managed.openshift.io" denied the request: Deleting ClusterRoleBinding must-gather-p7vwj is not allowedFor a complete list of all known issues in this release, see the list of OADP 1.2.2 known issues in Jira.
4.2.3. OADP 1.2.1 release notes
4.2.3.1. New features
There are no new features in the release of OpenShift API for Data Protection (OADP) 1.2.1.
4.2.3.2. Resolved issues
For a complete list of all issues resolved in the release of OADP 1.2.1, see the list of OADP 1.2.1 resolved issues in Jira.
4.2.3.3. Known issues
The following issues have been highlighted as known issues in the release of OADP 1.2.1:
DataMover Restic retain and prune policies do not work as expected
The retention and prune features provided by VolSync and Restic are not working as expected. Because there is no working option to set the prune interval on VolSync replication, you have to manage and prune remotely stored backups on S3 storage outside of OADP. For more details, see:
OADP Data Mover is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
For a complete list of all known issues in this release, see the list of OADP 1.2.1 known issues in Jira.
4.2.4. OADP 1.2.0 release notes
The OADP 1.2.0 release notes include information about new features, bug fixes, and known issues.
4.2.4.1. New features
Resource timeouts
							The new resourceTimeout option specifies the timeout duration in minutes for waiting on various Velero resources. This option applies to resources such as Velero CRD availability, volumeSnapshot deletion, and backup repository availability. The default duration is 10 minutes.
						
AWS S3 compatible backup storage providers
You can back up objects and snapshots on AWS S3 compatible providers. For more details, see Configuring Amazon Web Services.
4.2.4.1.1. Technical preview features
Data Mover
The OADP Data Mover enables you to back up Container Storage Interface (CSI) volume snapshots to a remote object store. When you enable Data Mover, you can restore stateful applications using CSI volume snapshots pulled from the object store in case of accidental cluster deletion, cluster failure, or data corruption. For more information, see Using Data Mover for CSI snapshots.
OADP Data Mover is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
4.2.4.2. Resolved issues
For a complete list of all issues resolved in this release, see the list of OADP 1.2.0 resolved issues in Jira.
4.2.4.3. Known issues
The following issues have been highlighted as known issues in the release of OADP 1.2.0:
Multiple HTTP/2 enabled web servers are vulnerable to a DDoS attack (Rapid Reset Attack)
The HTTP/2 protocol is susceptible to a denial of service attack because request cancellation can reset multiple streams quickly. The server has to set up and tear down the streams while not hitting any server-side limit for the maximum number of active streams per connection. This results in a denial of service due to server resource consumption. For a list of all OADP issues associated with this CVE, see the following Jira list.
It is advised to upgrade to OADP 1.2.3, which resolves this issue.
For more information, see CVE-2023-39325 (Rapid Reset Attack).
4.2.5. OADP 1.1.7 release notes
The OADP 1.1.7 release notes lists any resolved issues and known issues.
4.2.5.1. Resolved issues
The following highlighted issues are resolved in OADP 1.1.7:
Multiple HTTP/2 enabled web servers are vulnerable to a DDoS attack (Rapid Reset Attack)
In previous releases of OADP 1.1, the HTTP/2 protocol was susceptible to a denial of service attack because request cancellation could reset multiple streams quickly. The server had to set up and tear down the streams while not hitting any server-side limit for the maximum number of active streams per connection. This resulted in a denial of service due to server resource consumption. For a list of all OADP issues associated with this CVE, see the following Jira list.
For more information, see CVE-2023-39325 (Rapid Reset Attack).
For a complete list of all issues resolved in the release of OADP 1.1.7, see the list of OADP 1.1.7 resolved issues in Jira.
4.2.5.2. Known issues
There are no known issues in the release of OADP 1.1.7.
4.2.6. OADP 1.1.6 release notes
The OADP 1.1.6 release notes lists any new features, resolved issues and bugs, and known issues.
4.2.6.1. Resolved issues
Restic restore partially failing due to Pod Security standard
							OCP 4.14 introduced pod security standards that meant the privileged profile is enforced. In previous releases of OADP, this profile caused the pod to receive permission denied errors. This issue was caused because of the restore order. The pod was created before the security context constraints (SCC) resource. As this pod violated the pod security standard, the pod was denied and subsequently failed. OADP-2420
						
Restore partially failing for job resource
In previous releases of OADP, the restore of job resource was partially failing in OCP 4.14. This issue was not seen in older OCP versions. The issue was caused by an additional label being to the job resource, which was not present in older OCP versions. OADP-2530
For a complete list of all issues resolved in this release, see the list of OADP 1.1.6 resolved issues in Jira.
4.2.6.2. Known issues
For a complete list of all known issues in this release, see the list of OADP 1.1.6 known issues in Jira.
4.2.7. OADP 1.1.5 release notes
The OADP 1.1.5 release notes lists any new features, resolved issues and bugs, and known issues.
4.2.7.1. New features
This version of OADP is a service release. No new features are added to this version.
4.2.7.2. Resolved issues
For a complete list of all issues resolved in this release, see the list of OADP 1.1.5 resolved issues in Jira.
4.2.7.3. Known issues
For a complete list of all known issues in this release, see the list of OADP 1.1.5 known issues in Jira.
4.2.8. OADP 1.1.4 release notes
The OADP 1.1.4 release notes lists any new features, resolved issues and bugs, and known issues.
4.2.8.1. New features
This version of OADP is a service release. No new features are added to this version.
4.2.8.2. Resolved issues
Add support for all the velero deployment server arguments
In previous releases of OADP, OADP did not facilitate the support of all the upstream Velero server arguments. This issue has been resolved in OADP 1.1.4 and all the upstream Velero server arguments are supported. OADP-1557
Data Mover can restore from an incorrect snapshot when there was more than one VSR for the restore name and pvc name
							In previous releases of OADP, OADP Data Mover could restore from an incorrect snapshot if there was more than one Volume Snapshot Restore (VSR) resource in the cluster for the same Velero restore name and PersistentVolumeClaim (pvc) name. OADP-1822
						
Cloud Storage API BSLs need OwnerReference
							In previous releases of OADP, ACM BackupSchedules failed validation because of a missing OwnerReference on Backup Storage Locations (BSLs) created with dpa.spec.backupLocations.bucket. OADP-1511
						
For a complete list of all issues resolved in this release, see the list of OADP 1.1.4 resolved issues in Jira.
4.2.8.3. Known issues
This release has the following known issues:
OADP backups might fail because a UID/GID range might have changed on the cluster
OADP backups might fail because a UID/GID range might have changed on the cluster where the application has been restored, with the result that OADP does not back up and restore OpenShift Container Platform UID/GID range metadata. To avoid the issue, if the backed application requires a specific UUID, ensure the range is available when restored. An additional workaround is to allow OADP to create the namespace in the restore operation.
A restoration might fail if ArgoCD is used during the process due to a label used by ArgoCD
							A restoration might fail if ArgoCD is used during the process due to a label used by ArgoCD, app.kubernetes.io/instance. This label identifies which resources ArgoCD needs to manage, which can create a conflict with OADP’s procedure for managing resources on restoration. To work around this issue, set .spec.resourceTrackingMethod on the ArgoCD YAML to annotation+label or annotation. If the issue continues to persist, then disable ArgoCD before beginning to restore, and enable it again when restoration is finished.
						
OADP Velero plugins returning "received EOF, stopping recv loop" message
							Velero plugins are started as separate processes. When the Velero operation has completed, either successfully or not, they exit. Therefore if you see a received EOF, stopping recv loop messages in debug logs, it does not mean an error occurred. The message indicates that a plugin operation has completed. OADP-2176
						
For a complete list of all known issues in this release, see the list of OADP 1.1.4 known issues in Jira.
4.2.9. OADP 1.1.3 release notes
The OADP 1.1.3 release notes lists any new features, resolved issues and bugs, and known issues.
4.2.9.1. New features
This version of OADP is a service release. No new features are added to this version.
4.2.9.2. Resolved issues
For a complete list of all issues resolved in this release, see the list of OADP 1.1.3 resolved issues in Jira.
4.2.9.3. Known issues
For a complete list of all known issues in this release, see the list of OADP 1.1.3 known issues in Jira.
4.2.10. OADP 1.1.2 release notes
The OADP 1.1.2 release notes include product recommendations, a list of fixed bugs and descriptions of known issues.
4.2.10.1. Product recommendations
VolSync
							To prepare for the upgrade from VolSync 0.5.1 to the latest version available from the VolSync stable channel, you must add this annotation in the openshift-adp namespace by running the following command:
						
oc annotate --overwrite namespace/openshift-adp volsync.backube/privileged-movers='true'
$ oc annotate --overwrite namespace/openshift-adp volsync.backube/privileged-movers='true'Velero
In this release, Velero has been upgraded from version 1.9.2 to version 1.9.5.
Restic
In this release, Restic has been upgraded from version 0.13.1 to version 0.14.0.
4.2.10.2. Resolved issues
The following issues have been resolved in this release:
4.2.10.3. Known issues
This release has the following known issues:
- OADP currently does not support backup and restore of AWS EFS volumes using restic in Velero (OADP-778).
- CSI backups might fail due to a Ceph limitation of - VolumeSnapshotContentsnapshots per PVC.- You can create many snapshots of the same persistent volume claim (PVC) but cannot schedule periodic creation of snapshots: - For more information, see Volume Snapshots. 
4.2.11. OADP 1.1.1 release notes
The OADP 1.1.1 release notes include product recommendations and descriptions of known issues.
4.2.11.1. Product recommendations
Before you install OADP 1.1.1, it is recommended to either install VolSync 0.5.1 or to upgrade to it.
4.2.11.2. Known issues
This release has the following known issues:
- Multiple HTTP/2 enabled web servers are vulnerable to a DDoS attack (Rapid Reset Attack) - The HTTP/2 protocol is susceptible to a denial of service attack because request cancellation can reset multiple streams quickly. The server has to set up and tear down the streams while not hitting any server-side limit for the maximum number of active streams per connection. This results in a denial of service due to server resource consumption. For a list of all OADP issues associated with this CVE, see the following Jira list. - It is advised to upgrade to OADP 1.1.7 or 1.2.3, which resolve this issue. - For more information, see CVE-2023-39325 (Rapid Reset Attack). 
- OADP currently does not support backup and restore of AWS EFS volumes using restic in Velero (OADP-778).
- CSI backups might fail due to a Ceph limitation of - VolumeSnapshotContentsnapshots per PVC.- You can create many snapshots of the same persistent volume claim (PVC) but cannot schedule periodic creation of snapshots: - For CephFS, you can create up to 100 snapshots per PVC.
- For RADOS Block Device (RBD), you can create up to 512 snapshots for each PVC. (OADP-804) and (OADP-975) - For more information, see Volume Snapshots. 
 
4.3. OADP features and plugins
OpenShift API for Data Protection (OADP) features provide options for backing up and restoring applications.
The default plugins enable Velero to integrate with certain cloud providers and to back up and restore OpenShift Container Platform resources.
4.3.1. OADP features
OpenShift API for Data Protection (OADP) supports the following features:
- Backup
- You can use OADP to back up all applications on the OpenShift Platform, or you can filter the resources by type, namespace, or label. - OADP backs up Kubernetes objects and internal images by saving them as an archive file on object storage. OADP backs up persistent volumes (PVs) by creating snapshots with the native cloud snapshot API or with the Container Storage Interface (CSI). For cloud providers that do not support snapshots, OADP backs up resources and PV data with Restic. Note- You must exclude Operators from the backup of an application for backup and restore to succeed. 
- Restore
- You can restore resources and PVs from a backup. You can restore all objects in a backup or filter the objects by namespace, PV, or label. Note- You must exclude Operators from the backup of an application for backup and restore to succeed. 
- Schedule
- You can schedule backups at specified intervals.
- Hooks
- 
								You can use hooks to run commands in a container on a pod, for example, fsfreezeto freeze a file system. You can configure a hook to run before or after a backup or restore. Restore hooks can run in an init container or in the application container.
4.3.2. OADP plugins
The OpenShift API for Data Protection (OADP) provides default Velero plugins that are integrated with storage providers to support backup and snapshot operations. You can create custom plugins based on the Velero plugins.
OADP also provides plugins for OpenShift Container Platform resource backups, OpenShift Virtualization resource backups, and Container Storage Interface (CSI) snapshots.
| OADP plugin | Function | Storage location | 
|---|---|---|
| 
									 | Backs up and restores Kubernetes objects. | AWS S3 | 
| Backs up and restores volumes with snapshots. | AWS EBS | |
| 
									 | Backs up and restores Kubernetes objects. | Microsoft Azure Blob storage | 
| Backs up and restores volumes with snapshots. | Microsoft Azure Managed Disks | |
| 
									 | Backs up and restores Kubernetes objects. | Google Cloud Storage | 
| Backs up and restores volumes with snapshots. | Google Compute Engine Disks | |
| 
									 | Backs up and restores OpenShift Container Platform resources. [1] | Object store | 
| 
									 | Backs up and restores OpenShift Virtualization resources. [2] | Object store | 
| 
									 | Backs up and restores volumes with CSI snapshots. [3] | Cloud storage that supports CSI snapshots | 
- Mandatory.
- Virtual machine disks are backed up with CSI snapshots or Restic.
- 
							The csiplugin uses the Velero CSI beta snapshot API.
4.3.3. About OADP Velero plugins
You can configure two types of plugins when you install Velero:
- Default cloud provider plugins
- Custom plugins
Both types of plugin are optional, but most users configure at least one cloud provider plugin.
4.3.3.1. Default Velero cloud provider plugins
						You can install any of the following default Velero cloud provider plugins when you configure the oadp_v1alpha1_dpa.yaml file during deployment:
					
- 
								aws(Amazon Web Services)
- 
								gcp(Google Cloud Platform)
- 
								azure(Microsoft Azure)
- 
								openshift(OpenShift Velero plugin)
- 
								csi(Container Storage Interface)
- 
								kubevirt(KubeVirt)
						You specify the desired default plugins in the oadp_v1alpha1_dpa.yaml file during deployment.
					
Example file
							The following .yaml file installs the openshift, aws, azure, and gcp plugins:
						
4.3.3.2. Custom Velero plugins
						You can install a custom Velero plugin by specifying the plugin image and name when you configure the oadp_v1alpha1_dpa.yaml file during deployment.
					
						You specify the desired custom plugins in the oadp_v1alpha1_dpa.yaml file during deployment.
					
Example file
							The following .yaml file installs the default openshift, azure, and gcp plugins and a custom plugin that has the name custom-plugin-example and the image quay.io/example-repo/custom-velero-plugin:
						
4.3.3.3. Velero plugins returning "received EOF, stopping recv loop" message
							Velero plugins are started as separate processes. After the Velero operation has completed, either successfully or not, they exit. Receiving a received EOF, stopping recv loop message in the debug logs indicates that a plugin operation has completed. It does not mean that an error has occurred.
						
4.3.4. Supported architectures for OADP
OpenShift API for Data Protection (OADP) supports the following architectures:
- AMD64
- ARM64
- PPC64le
- s390x
OADP 1.2.0 and later versions support the ARM64 architecture.
4.3.5. OADP support for IBM Power and IBM Z
OpenShift API for Data Protection (OADP) is platform neutral. The information that follows relates only to IBM Power and to IBM Z.
OADP 1.1.0 was tested successfully against OpenShift Container Platform 4.11 for both IBM Power and IBM Z. The sections that follow give testing and support information for OADP 1.1.0 in terms of backup locations for these systems.
4.3.5.1. OADP support for target backup locations using IBM Power
IBM Power running with OpenShift Container Platform 4.11 and 4.12, and OpenShift API for Data Protection (OADP) 1.1.2 was tested successfully against an AWS S3 backup location target. Although the test involved only an AWS S3 target, Red Hat supports running IBM Power with OpenShift Container Platform 4.11 and 4.12, and OADP 1.1.2 against all non-AWS S3 backup location targets as well.
4.3.5.2. OADP testing and support for target backup locations using IBM Z
IBM Z running with OpenShift Container Platform 4.11 and 4.12, and OpenShift API for Data Protection (OADP) 1.1.2 was tested successfully against an AWS S3 backup location target. Although the test involved only an AWS S3 target, Red Hat supports running IBM Z with OpenShift Container Platform 4.11 and 4.12, and OADP 1.1.2 against all non-AWS S3 backup location targets as well.
4.4. Installing and configuring OADP
4.4.1. About installing OADP
As a cluster administrator, you install the OpenShift API for Data Protection (OADP) by installing the OADP Operator. The OADP Operator installs Velero 1.11.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
To back up Kubernetes resources and internal images, you must have object storage as a backup location, such as one of the following storage types:
- Amazon Web Services
- Microsoft Azure
- Google Cloud Platform
- Multicloud Object Gateway
- AWS S3 compatible object storage, such as Multicloud Object Gateway or MinIO
Unless specified otherwise, "NooBaa" refers to the open source project that provides lightweight object storage, while "Multicloud Object Gateway (MCG)" refers to the Red Hat distribution of NooBaa.
For more information on the MCG, see Accessing the Multicloud Object Gateway with your applications.
						The CloudStorage API, which automates the creation of a bucket for object storage, is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
					
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
You can back up persistent volumes (PVs) by using snapshots or Restic.
To back up PVs with snapshots, you must have a cloud provider that supports either a native snapshot API or Container Storage Interface (CSI) snapshots, such as one of the following cloud providers:
- Amazon Web Services
- Microsoft Azure
- Google Cloud Platform
- CSI snapshot-enabled cloud provider, such as OpenShift Data Foundation
If you want to use CSI backup on OCP 4.11 and later, install OADP 1.1.x.
						OADP 1.0.x does not support CSI backup on OCP 4.11 and later. OADP 1.0.x includes Velero 1.7.x and expects the API group snapshot.storage.k8s.io/v1beta1, which is not present on OCP 4.11 and later.
					
If your cloud provider does not support snapshots or if your storage is NFS, you can back up applications with Restic backups on object storage.
					You create a default Secret and then you install the Data Protection Application.
				
4.4.1.1. AWS S3 compatible backup storage providers
OADP is compatible with many object storage providers for use with different backup and snapshot operations. Several object storage providers are fully supported, several are unsupported but known to work, and some have known limitations.
4.4.1.1.1. Supported backup storage providers
The following AWS S3 compatible object storage providers are fully supported by OADP through the AWS plugin for use as backup storage locations:
- MinIO
- Multicloud Object Gateway (MCG)
- Amazon Web Services (AWS) S3
The following compatible object storage providers are supported and have their own Velero object store plugins:
- Google Cloud Platform (GCP)
- Microsoft Azure
4.4.1.1.2. Unsupported backup storage providers
The following AWS S3 compatible object storage providers, are known to work with Velero through the AWS plugin, for use as backup storage locations, however, they are unsupported and have not been tested by Red Hat:
- IBM Cloud
- Oracle Cloud
- DigitalOcean
- NooBaa, unless installed using Multicloud Object Gateway (MCG)
- Tencent Cloud
- Ceph RADOS v12.2.7
- Quobyte
- Cloudian HyperStore
Unless specified otherwise, "NooBaa" refers to the open source project that provides lightweight object storage, while "Multicloud Object Gateway (MCG)" refers to the Red Hat distribution of NooBaa.
For more information on the MCG, see Accessing the Multicloud Object Gateway with your applications.
4.4.1.1.3. Backup storage providers with known limitations
The following AWS S3 compatible object storage providers are known to work with Velero through the AWS plugin with a limited feature set:
- Swift - It works for use as a backup storage location for backup storage, but is not compatible with Restic for filesystem-based volume backup and restore.
4.4.1.2. Configuring Multicloud Object Gateway (MCG) for disaster recovery on OpenShift Data Foundation
						If you use cluster storage for your MCG bucket backupStorageLocation on OpenShift Data Foundation, configure MCG as an external object store.
					
Failure to configure MCG as an external object store might lead to backups not being available.
Unless specified otherwise, "NooBaa" refers to the open source project that provides lightweight object storage, while "Multicloud Object Gateway (MCG)" refers to the Red Hat distribution of NooBaa.
For more information on the MCG, see Accessing the Multicloud Object Gateway with your applications.
Procedure
- Configure MCG as an external object store as described in Adding storage resources for hybrid or Multicloud.
4.4.1.3. About OADP update channels
When you install an OADP Operator, you choose an update channel. This channel determines which upgrades to the OADP Operator and to Velero you receive. You can switch channels at any time.
The following update channels are available:
- 
								The stable channel is now deprecated. The stable channel contains the patches (z-stream updates) of OADP ClusterServiceVersionforoadp.v1.1.zand older versions fromoadp.v1.0.z.
- 
								The stable-1.0 channel contains oadp.v1.0.z, the most recent OADP 1.0ClusterServiceVersion.
- 
								The stable-1.1 channel contains oadp.v1.1.z, the most recent OADP 1.1ClusterServiceVersion.
- 
								The stable-1.2 channel contains oadp.v1.2.z, the most recent OADP 1.2ClusterServiceVersion.
- 
								The stable-1.3 channel contains oadp.v1.3.z, the most recent OADP 1.3ClusterServiceVersion.
Which update channel is right for you?
- 
								The stable channel is now deprecated. If you are already using the stable channel, you will continue to get updates from oadp.v1.1.z.
- Choose the stable-1.y update channel to install OADP 1.y and to continue receiving patches for it. If you choose this channel, you will receive all z-stream patches for version 1.y.z.
When must you switch update channels?
- If you have OADP 1.y installed, and you want to receive patches only for that y-stream, you must switch from the stable update channel to the stable-1.y update channel. You will then receive all z-stream patches for version 1.y.z.
- If you have OADP 1.0 installed, want to upgrade to OADP 1.1, and then receive patches only for OADP 1.1, you must switch from the stable-1.0 update channel to the stable-1.1 update channel. You will then receive all z-stream patches for version 1.1.z.
- If you have OADP 1.y installed, with y greater than 0, and want to switch to OADP 1.0, you must uninstall your OADP Operator and then reinstall it using the stable-1.0 update channel. You will then receive all z-stream patches for version 1.0.z.
You cannot switch from OADP 1.y to OADP 1.0 by switching update channels. You must uninstall the Operator and then reinstall it.
4.4.1.4. Installation of OADP on multiple namespaces
You can install OADP into multiple namespaces on the same cluster so that multiple project owners can manage their own OADP instance. This use case has been validated with Restic and CSI.
You install each instance of OADP as specified by the per-platform procedures contained in this document with the following additional requirements:
- All deployments of OADP on the same cluster must be the same version, for example, 1.1.4. Installing different versions of OADP on the same cluster is not supported.
- 
								Each individual deployment of OADP must have a unique set of credentials and a unique BackupStorageLocationconfiguration.
- By default, each OADP deployment has cluster-level access across namespaces. OpenShift Container Platform administrators need to review security and RBAC settings carefully and make any necessary changes to them to ensure that each OADP instance has the correct permissions.
4.4.1.5. Velero CPU and memory requirements based on collected data
The following recommendations are based on observations of performance made in the scale and performance lab. The backup and restore resources can be impacted by the type of plugin, the amount of resources required by that backup or restore, and the respective data contained in the persistent volumes (PVs) related to those resources.
4.4.1.5.1. CPU and memory requirement for configurations
| Configuration types | [1] Average usage | [2] Large usage | resourceTimeouts | 
|---|---|---|---|
| CSI | Velero: CPU- Request 200m, Limits 1000m Memory - Request 256Mi, Limits 1024Mi | Velero: CPU- Request 200m, Limits 2000m Memory- Request 256Mi, Limits 2048Mi | N/A | 
| Restic | [3] Restic: CPU- Request 1000m, Limits 2000m Memory - Request 16Gi, Limits 32Gi | [4] Restic: CPU - Request 2000m, Limits 8000m Memory - Request 16Gi, Limits 40Gi | 900m | 
| [5] DataMover | N/A | N/A | 10m - average usage 60m - large usage | 
- Average usage - use these settings for most usage situations.
- Large usage - use these settings for large usage situations, such as a large PV (500GB Usage), multiple namespaces (100+), or many pods within a single namespace (2000 pods+), and for optimal performance for backup and restore involving large datasets.
- Restic resource usage corresponds to the amount of data, and type of data. For example, many small files or large amounts of data can cause Restic to utilize large amounts of resources. The Velero documentation references 500m as a supplied default, for most of our testing we found 200m request suitable with 1000m limit. As cited in the Velero documentation, exact CPU and memory usage is dependent on the scale of files and directories, in addition to environmental limitations.
- Increasing the CPU has a significant impact on improving backup and restore times.
- DataMover - DataMover default resourceTimeout is 10m. Our tests show that for restoring a large PV (500GB usage), it is required to increase the resourceTimeout to 60m.
The resource requirements listed throughout the guide are for average usage only. For large usage, adjust the settings as described in the table above.
4.4.1.5.2. NodeAgent CPU for large usage
							Testing shows that increasing NodeAgent CPU can significantly improve backup and restore times when using OpenShift API for Data Protection (OADP).
						
It is not recommended to use Kopia without limits in production environments on nodes running production workloads due to Kopia’s aggressive consumption of resources. However, running Kopia with limits that are too low results in CPU limiting and slow backups and restore situations. Testing showed that running Kopia with 20 cores and 32 Gi memory supported backup and restore operations of over 100 GB of data, multiple namespaces, or over 2000 pods in a single namespace.
Testing detected no CPU limiting or memory saturation with these resource specifications.
You can set these limits in Ceph MDS pods by following the procedure in Changing the CPU and memory resources on the rook-ceph pods.
You need to add the following lines to the storage cluster Custom Resource (CR) to set the limits:
4.4.2. Installing the OADP Operator
You can install the OpenShift API for Data Protection (OADP) Operator on OpenShift Container Platform 4.11 by using Operator Lifecycle Manager (OLM).
The OADP Operator installs Velero 1.11.
Prerequisites
- 
							You must be logged in as a user with cluster-adminprivileges.
Procedure
- 
							In the OpenShift Container Platform web console, click Operators OperatorHub. 
- Use the Filter by keyword field to find the OADP Operator.
- Select the OADP Operator and click Install.
- 
							Click Install to install the Operator in the openshift-adpproject.
- 
							Click Operators Installed Operators to verify the installation. 
4.4.2.1. OADP-Velero-OpenShift Container Platform version relationship
| OADP version | Velero version | OpenShift Container Platform version | 
|---|---|---|
| 1.1.0 | 4.9 and later | |
| 1.1.1 | 4.9 and later | |
| 1.1.2 | 4.9 and later | |
| 1.1.3 | 4.9 and later | |
| 1.1.4 | 4.9 and later | |
| 1.1.5 | 4.9 and later | |
| 1.1.6 | 4.11 and later | |
| 1.1.7 | 4.11 and later | |
| 1.2.0 | 4.11 and later | |
| 1.2.1 | 4.11 and later | |
| 1.2.2 | 4.11 and later | |
| 1.2.3 | 4.11 and later | 
4.4.3. Configuring the OpenShift API for Data Protection with Amazon Web Services
You install the OpenShift API for Data Protection (OADP) with Amazon Web Services (AWS) by installing the OADP Operator. The Operator installs Velero 1.11.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
					You configure AWS for Velero, create a default Secret, and then install the Data Protection Application. For more details, see Installing the OADP Operator.
				
To install the OADP Operator in a restricted network environment, you must first disable the default OperatorHub sources and mirror the Operator catalog. See Using Operator Lifecycle Manager on restricted networks for details.
4.4.3.1. Configuring Amazon Web Services
You configure Amazon Web Services (AWS) for the OpenShift API for Data Protection (OADP).
Prerequisites
- You must have the AWS CLI installed.
Procedure
- Set the - BUCKETvariable:- BUCKET=<your_bucket> - $ BUCKET=<your_bucket>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - REGIONvariable:- REGION=<your_region> - $ REGION=<your_region>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create an AWS S3 bucket: - aws s3api create-bucket \ --bucket $BUCKET \ --region $REGION \ --create-bucket-configuration LocationConstraint=$REGION- $ aws s3api create-bucket \ --bucket $BUCKET \ --region $REGION \ --create-bucket-configuration LocationConstraint=$REGION- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- us-east-1does not support a- LocationConstraint. If your region is- us-east-1, omit- --create-bucket-configuration LocationConstraint=$REGION.
 
- Create an IAM user: - aws iam create-user --user-name velero - $ aws iam create-user --user-name velero- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- If you want to use Velero to back up multiple clusters with multiple S3 buckets, create a unique user name for each cluster.
 
- Create a - velero-policy.jsonfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Attach the policies to give the - velerouser the minimum necessary permissions:- aws iam put-user-policy \ --user-name velero \ --policy-name velero \ --policy-document file://velero-policy.json - $ aws iam put-user-policy \ --user-name velero \ --policy-name velero \ --policy-document file://velero-policy.json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create an access key for the - velerouser:- aws iam create-access-key --user-name velero - $ aws iam create-access-key --user-name velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - credentials-velerofile:- cat << EOF > ./credentials-velero [default] aws_access_key_id=<AWS_ACCESS_KEY_ID> aws_secret_access_key=<AWS_SECRET_ACCESS_KEY> EOF - $ cat << EOF > ./credentials-velero [default] aws_access_key_id=<AWS_ACCESS_KEY_ID> aws_secret_access_key=<AWS_SECRET_ACCESS_KEY> EOF- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You use the - credentials-velerofile to create a- Secretobject for AWS before you install the Data Protection Application.
4.4.3.2. About backup and snapshot locations and their secrets
						You specify backup and snapshot locations and their secrets in the DataProtectionApplication custom resource (CR).
					
Backup locations
You specify S3-compatible object storage, such as Multicloud Object Gateway or MinIO, as a backup location.
Velero backs up OpenShift Container Platform resources, Kubernetes objects, and internal images as an archive file on object storage.
Snapshot locations
If you use your cloud provider’s native snapshot API to back up persistent volumes, you must specify the cloud provider as the snapshot location.
						If you use Container Storage Interface (CSI) snapshots, you do not need to specify a snapshot location because you will create a VolumeSnapshotClass CR to register the CSI driver.
					
If you use Restic, you do not need to specify a snapshot location because Restic backs up the file system on object storage.
Secrets
						If the backup and snapshot locations use the same credentials or if you do not require a snapshot location, you create a default Secret.
					
If the backup and snapshot locations use different credentials, you create two secret objects:
- 
								Custom Secretfor the backup location, which you specify in theDataProtectionApplicationCR.
- 
								Default Secretfor the snapshot location, which is not referenced in theDataProtectionApplicationCR.
							The Data Protection Application requires a default Secret. Otherwise, the installation will fail.
						
							If you do not want to specify backup or snapshot locations during the installation, you can create a default Secret with an empty credentials-velero file.
						
4.4.3.2.1. Creating a default Secret
							You create a default Secret if your backup and snapshot locations use the same credentials or if you do not require a snapshot location.
						
							The default name of the Secret is cloud-credentials.
						
								The DataProtectionApplication custom resource (CR) requires a default Secret. Otherwise, the installation will fail. If the name of the backup location Secret is not specified, the default name is used.
							
								If you do not want to use the backup location credentials during the installation, you can create a Secret with the default name by using an empty credentials-velero file.
							
Prerequisites
- Your object storage and cloud storage, if any, must use the same credentials.
- You must configure object storage for Velero.
- 
									You must create a credentials-velerofile for the object storage in the appropriate format.
Procedure
- Create a - Secretwith the default name:- oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
							The Secret is referenced in the spec.backupLocations.credential block of the DataProtectionApplication CR when you install the Data Protection Application.
						
4.4.3.2.2. Creating profiles for different credentials
							If your backup and snapshot locations use different credentials, you create separate profiles in the credentials-velero file.
						
							Then, you create a Secret object and specify the profiles in the DataProtectionApplication custom resource (CR).
						
Procedure
- Create a - credentials-velerofile with separate profiles for the backup and snapshot locations, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - Secretobject with the- credentials-velerofile:- oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the profiles to the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.3.3. Configuring the Data Protection Application
You can configure the Data Protection Application by setting Velero resource allocations or enabling self-signed CA certificates.
4.4.3.3.1. Setting Velero CPU and memory resource allocations
							You set the CPU and memory resource allocations for the Velero pod by editing the DataProtectionApplication custom resource (CR) manifest.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the values in the - spec.configuration.velero.podConfig.ResourceAllocationsblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.3.3.2. Enabling self-signed CA certificates
							You must enable a self-signed CA certificate for object storage by editing the DataProtectionApplication custom resource (CR) manifest to prevent a certificate signed by unknown authority error.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the - spec.backupLocations.velero.objectStorage.caCertparameter and- spec.backupLocations.velero.configparameters of the- DataProtectionApplicationCR manifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.3.4. Installing the Data Protection Application
						You install the Data Protection Application (DPA) by creating an instance of the DataProtectionApplication API.
					
Prerequisites
- You must install the OADP Operator.
- You must configure object storage as a backup location.
- If you use snapshots to back up PVs, your cloud provider must support either a native snapshot API or Container Storage Interface (CSI) snapshots.
- 
								If the backup and snapshot locations use the same credentials, you must create a Secretwith the default name,cloud-credentials.
- If the backup and snapshot locations use different credentials, you must create a - Secretwith the default name,- cloud-credentials, which contains separate profiles for the backup and snapshot location credentials.Note- If you do not want to specify backup or snapshot locations during the installation, you can create a default - Secretwith an empty- credentials-velerofile. If there is no default- Secret, the installation will fail.Note- Velero creates a secret named - velero-repo-credentialsin the OADP namespace, which contains a default backup repository password. You can update the secret with your own password encoded as base64 before you run your first backup targeted to the backup repository. The value of the key to update is- Data[repository-password].- After you create your DPA, the first time that you run a backup targeted to the backup repository, Velero creates a backup repository whose secret is - velero-repo-credentials, which contains either the default password or the one you replaced it with. If you update the secret password after the first backup, the new password will not match the password in- velero-repo-credentials, and therefore, Velero will not be able to connect with the older backups.
Procedure
- 
								Click Operators Installed Operators and select the OADP Operator. 
- Under Provided APIs, click Create instance in the DataProtectionApplication box.
- Click YAML View and update the parameters of the - DataProtectionApplicationmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theopenshiftplugin is mandatory.
- 2
- Specify how many minutes to wait for several Velero resources before timeout occurs, such as Velero CRD availability, volumeSnapshot deletion, and backup repository availability. The default is 10m.
- 3
- Set this value tofalseif you want to disable the Restic installation. Restic deploys a daemon set, which means that Restic pods run on each working node. In OADP version 1.2 and later, you can configure Restic for backups by addingspec.defaultVolumesToFsBackup: trueto theBackupCR. In OADP version 1.1, addspec.defaultVolumesToRestic: trueto theBackupCR.
- 4
- Specify on which nodes Restic is available. By default, Restic runs on all nodes.
- 5
- Specify a bucket as the backup storage location. If the bucket is not a dedicated bucket for Velero backups, you must specify a prefix.
- 6
- Specify a prefix for Velero backups, for example,velero, if the bucket is used for multiple purposes.
- 7
- Specify the name of theSecretobject that you created. If you do not specify this value, the default name,cloud-credentials, is used. If you specify a custom name, the custom name is used for the backup location.
- 8
- Specify a snapshot location, unless you use CSI snapshots or Restic to back up PVs.
- 9
- The snapshot location must be in the same region as the PVs.
 
- Click Create.
- Verify the installation by viewing the OADP resources: - oc get all -n openshift-adp - $ oc get all -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.3.4.1. Enabling CSI in the DataProtectionApplication CR
							You enable the Container Storage Interface (CSI) in the DataProtectionApplication custom resource (CR) in order to back up persistent volumes with CSI snapshots.
						
Prerequisites
- The cloud provider must support CSI snapshots.
Procedure
- Edit the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add thecsidefault plugin.
 
4.4.4. Configuring the OpenShift API for Data Protection with Microsoft Azure
You install the OpenShift API for Data Protection (OADP) with Microsoft Azure by installing the OADP Operator. The Operator installs Velero 1.11.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
					You configure Azure for Velero, create a default Secret, and then install the Data Protection Application. For more details, see Installing the OADP Operator.
				
To install the OADP Operator in a restricted network environment, you must first disable the default OperatorHub sources and mirror the Operator catalog. See Using Operator Lifecycle Manager on restricted networks for details.
4.4.4.1. Configuring Microsoft Azure
You configure a Microsoft Azure for the OpenShift API for Data Protection (OADP).
Prerequisites
- You must have the Azure CLI installed.
Procedure
- Log in to Azure: - az login - $ az login- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - AZURE_RESOURCE_GROUPvariable:- AZURE_RESOURCE_GROUP=Velero_Backups - $ AZURE_RESOURCE_GROUP=Velero_Backups- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create an Azure resource group: - az group create -n $AZURE_RESOURCE_GROUP --location CentralUS - $ az group create -n $AZURE_RESOURCE_GROUP --location CentralUS- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify your location.
 
- Set the - AZURE_STORAGE_ACCOUNT_IDvariable:- AZURE_STORAGE_ACCOUNT_ID="velero$(uuidgen | cut -d '-' -f5 | tr '[A-Z]' '[a-z]')" - $ AZURE_STORAGE_ACCOUNT_ID="velero$(uuidgen | cut -d '-' -f5 | tr '[A-Z]' '[a-z]')"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create an Azure storage account: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - BLOB_CONTAINERvariable:- BLOB_CONTAINER=velero - $ BLOB_CONTAINER=velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create an Azure Blob storage container: - az storage container create \ -n $BLOB_CONTAINER \ --public-access off \ --account-name $AZURE_STORAGE_ACCOUNT_ID - $ az storage container create \ -n $BLOB_CONTAINER \ --public-access off \ --account-name $AZURE_STORAGE_ACCOUNT_ID- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Obtain the storage account access key: - AZURE_STORAGE_ACCOUNT_ACCESS_KEY=`az storage account keys list \ --account-name $AZURE_STORAGE_ACCOUNT_ID \ --query "[?keyName == 'key1'].value" -o tsv` - $ AZURE_STORAGE_ACCOUNT_ACCESS_KEY=`az storage account keys list \ --account-name $AZURE_STORAGE_ACCOUNT_ID \ --query "[?keyName == 'key1'].value" -o tsv`- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a custom role that has the minimum required permissions: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - credentials-velerofile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Mandatory. You cannot back up internal images if thecredentials-velerofile contains only the service principal credentials.
 - You use the - credentials-velerofile to create a- Secretobject for Azure before you install the Data Protection Application.
4.4.4.2. About backup and snapshot locations and their secrets
						You specify backup and snapshot locations and their secrets in the DataProtectionApplication custom resource (CR).
					
Backup locations
You specify S3-compatible object storage, such as Multicloud Object Gateway or MinIO, as a backup location.
Velero backs up OpenShift Container Platform resources, Kubernetes objects, and internal images as an archive file on object storage.
Snapshot locations
If you use your cloud provider’s native snapshot API to back up persistent volumes, you must specify the cloud provider as the snapshot location.
						If you use Container Storage Interface (CSI) snapshots, you do not need to specify a snapshot location because you will create a VolumeSnapshotClass CR to register the CSI driver.
					
If you use Restic, you do not need to specify a snapshot location because Restic backs up the file system on object storage.
Secrets
						If the backup and snapshot locations use the same credentials or if you do not require a snapshot location, you create a default Secret.
					
If the backup and snapshot locations use different credentials, you create two secret objects:
- 
								Custom Secretfor the backup location, which you specify in theDataProtectionApplicationCR.
- 
								Default Secretfor the snapshot location, which is not referenced in theDataProtectionApplicationCR.
							The Data Protection Application requires a default Secret. Otherwise, the installation will fail.
						
							If you do not want to specify backup or snapshot locations during the installation, you can create a default Secret with an empty credentials-velero file.
						
4.4.4.2.1. Creating a default Secret
							You create a default Secret if your backup and snapshot locations use the same credentials or if you do not require a snapshot location.
						
							The default name of the Secret is cloud-credentials-azure.
						
								The DataProtectionApplication custom resource (CR) requires a default Secret. Otherwise, the installation will fail. If the name of the backup location Secret is not specified, the default name is used.
							
								If you do not want to use the backup location credentials during the installation, you can create a Secret with the default name by using an empty credentials-velero file.
							
Prerequisites
- Your object storage and cloud storage, if any, must use the same credentials.
- You must configure object storage for Velero.
- 
									You must create a credentials-velerofile for the object storage in the appropriate format.
Procedure
- Create a - Secretwith the default name:- oc create secret generic cloud-credentials-azure -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials-azure -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
							The Secret is referenced in the spec.backupLocations.credential block of the DataProtectionApplication CR when you install the Data Protection Application.
						
4.4.4.2.2. Creating secrets for different credentials
							If your backup and snapshot locations use different credentials, you must create two Secret objects:
						
- 
									Backup location Secretwith a custom name. The custom name is specified in thespec.backupLocationsblock of theDataProtectionApplicationcustom resource (CR).
- 
									Snapshot location Secretwith the default name,cloud-credentials-azure. ThisSecretis not specified in theDataProtectionApplicationCR.
Procedure
- 
									Create a credentials-velerofile for the snapshot location in the appropriate format for your cloud provider.
- Create a - Secretfor the snapshot location with the default name:- oc create secret generic cloud-credentials-azure -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials-azure -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Create a credentials-velerofile for the backup location in the appropriate format for your object storage.
- Create a - Secretfor the backup location with a custom name:- oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the - Secretwith the custom name to the- DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Backup locationSecretwith custom name.
 
4.4.4.3. Configuring the Data Protection Application
You can configure the Data Protection Application by setting Velero resource allocations or enabling self-signed CA certificates.
4.4.4.3.1. Setting Velero CPU and memory resource allocations
							You set the CPU and memory resource allocations for the Velero pod by editing the DataProtectionApplication custom resource (CR) manifest.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the values in the - spec.configuration.velero.podConfig.ResourceAllocationsblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.4.3.2. Enabling self-signed CA certificates
							You must enable a self-signed CA certificate for object storage by editing the DataProtectionApplication custom resource (CR) manifest to prevent a certificate signed by unknown authority error.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the - spec.backupLocations.velero.objectStorage.caCertparameter and- spec.backupLocations.velero.configparameters of the- DataProtectionApplicationCR manifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.4.4. Installing the Data Protection Application
						You install the Data Protection Application (DPA) by creating an instance of the DataProtectionApplication API.
					
Prerequisites
- You must install the OADP Operator.
- You must configure object storage as a backup location.
- If you use snapshots to back up PVs, your cloud provider must support either a native snapshot API or Container Storage Interface (CSI) snapshots.
- 
								If the backup and snapshot locations use the same credentials, you must create a Secretwith the default name,cloud-credentials-azure.
- If the backup and snapshot locations use different credentials, you must create two - Secrets:- 
										Secretwith a custom name for the backup location. You add thisSecretto theDataProtectionApplicationCR.
- Secretwith the default name,- cloud-credentials-azure, for the snapshot location. This- Secretis not referenced in the- DataProtectionApplicationCR.Note- If you do not want to specify backup or snapshot locations during the installation, you can create a default - Secretwith an empty- credentials-velerofile. If there is no default- Secret, the installation will fail.Note- Velero creates a secret named - velero-repo-credentialsin the OADP namespace, which contains a default backup repository password. You can update the secret with your own password encoded as base64 before you run your first backup targeted to the backup repository. The value of the key to update is- Data[repository-password].- After you create your DPA, the first time that you run a backup targeted to the backup repository, Velero creates a backup repository whose secret is - velero-repo-credentials, which contains either the default password or the one you replaced it with. If you update the secret password after the first backup, the new password will not match the password in- velero-repo-credentials, and therefore, Velero will not be able to connect with the older backups.
 
- 
										
Procedure
- 
								Click Operators Installed Operators and select the OADP Operator. 
- Under Provided APIs, click Create instance in the DataProtectionApplication box.
- Click YAML View and update the parameters of the - DataProtectionApplicationmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theopenshiftplugin is mandatory.
- 2
- Specify how many minutes to wait for several Velero resources before timeout occurs, such as Velero CRD availability, volumeSnapshot deletion, and backup repository availability. The default is 10m.
- 3
- Set this value tofalseif you want to disable the Restic installation. Restic deploys a daemon set, which means that Restic pods run on each working node. In OADP version 1.2 and later, you can configure Restic for backups by addingspec.defaultVolumesToFsBackup: trueto theBackupCR. In OADP version 1.1, addspec.defaultVolumesToRestic: trueto theBackupCR.
- 4
- Specify on which nodes Restic is available. By default, Restic runs on all nodes.
- 5
- Specify the Azure resource group.
- 6
- Specify the Azure storage account ID.
- 7
- Specify the Azure subscription ID.
- 8
- If you do not specify this value, the default name,cloud-credentials-azure, is used. If you specify a custom name, the custom name is used for the backup location.
- 9
- Specify a bucket as the backup storage location. If the bucket is not a dedicated bucket for Velero backups, you must specify a prefix.
- 10
- Specify a prefix for Velero backups, for example,velero, if the bucket is used for multiple purposes.
- 11
- You do not need to specify a snapshot location if you use CSI snapshots or Restic to back up PVs.
 
- Click Create.
- Verify the installation by viewing the OADP resources: - oc get all -n openshift-adp - $ oc get all -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.4.4.1. Enabling CSI in the DataProtectionApplication CR
							You enable the Container Storage Interface (CSI) in the DataProtectionApplication custom resource (CR) in order to back up persistent volumes with CSI snapshots.
						
Prerequisites
- The cloud provider must support CSI snapshots.
Procedure
- Edit the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add thecsidefault plugin.
 
4.4.5. Configuring the OpenShift API for Data Protection with Google Cloud Platform
You install the OpenShift API for Data Protection (OADP) with Google Cloud Platform (GCP) by installing the OADP Operator. The Operator installs Velero 1.11.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
					You configure GCP for Velero, create a default Secret, and then install the Data Protection Application. For more details, see Installing the OADP Operator.
				
To install the OADP Operator in a restricted network environment, you must first disable the default OperatorHub sources and mirror the Operator catalog. See Using Operator Lifecycle Manager on restricted networks for details.
4.4.5.1. Configuring Google Cloud Platform
You configure Google Cloud Platform (GCP) for the OpenShift API for Data Protection (OADP).
Prerequisites
- 
								You must have the gcloudandgsutilCLI tools installed. See the Google cloud documentation for details.
Procedure
- Log in to GCP: - gcloud auth login - $ gcloud auth login- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - BUCKETvariable:- BUCKET=<bucket> - $ BUCKET=<bucket>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify your bucket name.
 
- Create the storage bucket: - gsutil mb gs://$BUCKET/ - $ gsutil mb gs://$BUCKET/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - PROJECT_IDvariable to your active project:- PROJECT_ID=$(gcloud config get-value project) - $ PROJECT_ID=$(gcloud config get-value project)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a service account: - gcloud iam service-accounts create velero \ --display-name "Velero service account"- $ gcloud iam service-accounts create velero \ --display-name "Velero service account"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- List your service accounts: - gcloud iam service-accounts list - $ gcloud iam service-accounts list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - SERVICE_ACCOUNT_EMAILvariable to match its- emailvalue:- SERVICE_ACCOUNT_EMAIL=$(gcloud iam service-accounts list \ --filter="displayName:Velero service account" \ --format 'value(email)')- $ SERVICE_ACCOUNT_EMAIL=$(gcloud iam service-accounts list \ --filter="displayName:Velero service account" \ --format 'value(email)')- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Attach the policies to give the - velerouser the minimum necessary permissions:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - velero.servercustom role:- gcloud iam roles create velero.server \ --project $PROJECT_ID \ --title "Velero Server" \ --permissions "$(IFS=","; echo "${ROLE_PERMISSIONS[*]}")"- $ gcloud iam roles create velero.server \ --project $PROJECT_ID \ --title "Velero Server" \ --permissions "$(IFS=","; echo "${ROLE_PERMISSIONS[*]}")"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add IAM policy binding to the project: - gcloud projects add-iam-policy-binding $PROJECT_ID \ --member serviceAccount:$SERVICE_ACCOUNT_EMAIL \ --role projects/$PROJECT_ID/roles/velero.server- $ gcloud projects add-iam-policy-binding $PROJECT_ID \ --member serviceAccount:$SERVICE_ACCOUNT_EMAIL \ --role projects/$PROJECT_ID/roles/velero.server- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Update the IAM service account: - gsutil iam ch serviceAccount:$SERVICE_ACCOUNT_EMAIL:objectAdmin gs://${BUCKET}- $ gsutil iam ch serviceAccount:$SERVICE_ACCOUNT_EMAIL:objectAdmin gs://${BUCKET}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save the IAM service account keys to the - credentials-velerofile in the current directory:- gcloud iam service-accounts keys create credentials-velero \ --iam-account $SERVICE_ACCOUNT_EMAIL- $ gcloud iam service-accounts keys create credentials-velero \ --iam-account $SERVICE_ACCOUNT_EMAIL- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You use the - credentials-velerofile to create a- Secretobject for GCP before you install the Data Protection Application.
4.4.5.2. About backup and snapshot locations and their secrets
						You specify backup and snapshot locations and their secrets in the DataProtectionApplication custom resource (CR).
					
Backup locations
You specify S3-compatible object storage, such as Multicloud Object Gateway or MinIO, as a backup location.
Velero backs up OpenShift Container Platform resources, Kubernetes objects, and internal images as an archive file on object storage.
Snapshot locations
If you use your cloud provider’s native snapshot API to back up persistent volumes, you must specify the cloud provider as the snapshot location.
						If you use Container Storage Interface (CSI) snapshots, you do not need to specify a snapshot location because you will create a VolumeSnapshotClass CR to register the CSI driver.
					
If you use Restic, you do not need to specify a snapshot location because Restic backs up the file system on object storage.
Secrets
						If the backup and snapshot locations use the same credentials or if you do not require a snapshot location, you create a default Secret.
					
If the backup and snapshot locations use different credentials, you create two secret objects:
- 
								Custom Secretfor the backup location, which you specify in theDataProtectionApplicationCR.
- 
								Default Secretfor the snapshot location, which is not referenced in theDataProtectionApplicationCR.
							The Data Protection Application requires a default Secret. Otherwise, the installation will fail.
						
							If you do not want to specify backup or snapshot locations during the installation, you can create a default Secret with an empty credentials-velero file.
						
4.4.5.2.1. Creating a default Secret
							You create a default Secret if your backup and snapshot locations use the same credentials or if you do not require a snapshot location.
						
							The default name of the Secret is cloud-credentials-gcp.
						
								The DataProtectionApplication custom resource (CR) requires a default Secret. Otherwise, the installation will fail. If the name of the backup location Secret is not specified, the default name is used.
							
								If you do not want to use the backup location credentials during the installation, you can create a Secret with the default name by using an empty credentials-velero file.
							
Prerequisites
- Your object storage and cloud storage, if any, must use the same credentials.
- You must configure object storage for Velero.
- 
									You must create a credentials-velerofile for the object storage in the appropriate format.
Procedure
- Create a - Secretwith the default name:- oc create secret generic cloud-credentials-gcp -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials-gcp -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
							The Secret is referenced in the spec.backupLocations.credential block of the DataProtectionApplication CR when you install the Data Protection Application.
						
4.4.5.2.2. Creating secrets for different credentials
							If your backup and snapshot locations use different credentials, you must create two Secret objects:
						
- 
									Backup location Secretwith a custom name. The custom name is specified in thespec.backupLocationsblock of theDataProtectionApplicationcustom resource (CR).
- 
									Snapshot location Secretwith the default name,cloud-credentials-gcp. ThisSecretis not specified in theDataProtectionApplicationCR.
Procedure
- 
									Create a credentials-velerofile for the snapshot location in the appropriate format for your cloud provider.
- Create a - Secretfor the snapshot location with the default name:- oc create secret generic cloud-credentials-gcp -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials-gcp -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Create a credentials-velerofile for the backup location in the appropriate format for your object storage.
- Create a - Secretfor the backup location with a custom name:- oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the - Secretwith the custom name to the- DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Backup locationSecretwith custom name.
 
4.4.5.3. Configuring the Data Protection Application
You can configure the Data Protection Application by setting Velero resource allocations or enabling self-signed CA certificates.
4.4.5.3.1. Setting Velero CPU and memory resource allocations
							You set the CPU and memory resource allocations for the Velero pod by editing the DataProtectionApplication custom resource (CR) manifest.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the values in the - spec.configuration.velero.podConfig.ResourceAllocationsblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.5.3.2. Enabling self-signed CA certificates
							You must enable a self-signed CA certificate for object storage by editing the DataProtectionApplication custom resource (CR) manifest to prevent a certificate signed by unknown authority error.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the - spec.backupLocations.velero.objectStorage.caCertparameter and- spec.backupLocations.velero.configparameters of the- DataProtectionApplicationCR manifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.5.4. Installing the Data Protection Application
						You install the Data Protection Application (DPA) by creating an instance of the DataProtectionApplication API.
					
Prerequisites
- You must install the OADP Operator.
- You must configure object storage as a backup location.
- If you use snapshots to back up PVs, your cloud provider must support either a native snapshot API or Container Storage Interface (CSI) snapshots.
- 
								If the backup and snapshot locations use the same credentials, you must create a Secretwith the default name,cloud-credentials-gcp.
- If the backup and snapshot locations use different credentials, you must create two - Secrets:- 
										Secretwith a custom name for the backup location. You add thisSecretto theDataProtectionApplicationCR.
- Secretwith the default name,- cloud-credentials-gcp, for the snapshot location. This- Secretis not referenced in the- DataProtectionApplicationCR.Note- If you do not want to specify backup or snapshot locations during the installation, you can create a default - Secretwith an empty- credentials-velerofile. If there is no default- Secret, the installation will fail.Note- Velero creates a secret named - velero-repo-credentialsin the OADP namespace, which contains a default backup repository password. You can update the secret with your own password encoded as base64 before you run your first backup targeted to the backup repository. The value of the key to update is- Data[repository-password].- After you create your DPA, the first time that you run a backup targeted to the backup repository, Velero creates a backup repository whose secret is - velero-repo-credentials, which contains either the default password or the one you replaced it with. If you update the secret password after the first backup, the new password will not match the password in- velero-repo-credentials, and therefore, Velero will not be able to connect with the older backups.
 
- 
										
Procedure
- 
								Click Operators Installed Operators and select the OADP Operator. 
- Under Provided APIs, click Create instance in the DataProtectionApplication box.
- Click YAML View and update the parameters of the - DataProtectionApplicationmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theopenshiftplugin is mandatory.
- 2
- Specify how many minutes to wait for several Velero resources before timeout occurs, such as Velero CRD availability, volumeSnapshot deletion, and backup repository availability. The default is 10m.
- 3
- Set this value tofalseif you want to disable the Restic installation. Restic deploys a daemon set, which means that Restic pods run on each working node. In OADP version 1.2 and later, you can configure Restic for backups by addingspec.defaultVolumesToFsBackup: trueto theBackupCR. In OADP version 1.1, addspec.defaultVolumesToRestic: trueto theBackupCR.
- 4
- Specify on which nodes Restic is available. By default, Restic runs on all nodes.
- 5
- If you do not specify this value, the default name,cloud-credentials-gcp, is used. If you specify a custom name, the custom name is used for the backup location.
- 6
- Specify a bucket as the backup storage location. If the bucket is not a dedicated bucket for Velero backups, you must specify a prefix.
- 7
- Specify a prefix for Velero backups, for example,velero, if the bucket is used for multiple purposes.
- 8
- Specify a snapshot location, unless you use CSI snapshots or Restic to back up PVs.
- 9
- The snapshot location must be in the same region as the PVs.
 
- Click Create.
- Verify the installation by viewing the OADP resources: - oc get all -n openshift-adp - $ oc get all -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.5.4.1. Enabling CSI in the DataProtectionApplication CR
							You enable the Container Storage Interface (CSI) in the DataProtectionApplication custom resource (CR) in order to back up persistent volumes with CSI snapshots.
						
Prerequisites
- The cloud provider must support CSI snapshots.
Procedure
- Edit the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add thecsidefault plugin.
 
4.4.6. Configuring the OpenShift API for Data Protection with Multicloud Object Gateway
You install the OpenShift API for Data Protection (OADP) with Multicloud Object Gateway (MCG) by installing the OADP Operator. The Operator installs Velero 1.11.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
					You configure Multicloud Object Gateway as a backup location. MCG is a component of OpenShift Data Foundation. You configure MCG as a backup location in the DataProtectionApplication custom resource (CR).
				
						The CloudStorage API, which automates the creation of a bucket for object storage, is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
					
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
					You create a Secret for the backup location and then you install the Data Protection Application. For more details, see Installing the OADP Operator.
				
To install the OADP Operator in a restricted network environment, you must first disable the default OperatorHub sources and mirror the Operator catalog. For details, see Using Operator Lifecycle Manager on restricted networks.
4.4.6.1. Retrieving Multicloud Object Gateway credentials
						You must retrieve the Multicloud Object Gateway (MCG) credentials in order to create a Secret custom resource (CR) for the OpenShift API for Data Protection (OADP).
					
MCG is a component of OpenShift Data Foundation.
Prerequisites
- You must deploy OpenShift Data Foundation by using the appropriate OpenShift Data Foundation deployment guide.
Procedure
- 
								Obtain the S3 endpoint, AWS_ACCESS_KEY_ID, andAWS_SECRET_ACCESS_KEYby running thedescribecommand on theNooBaacustom resource.
- Create a - credentials-velerofile:- cat << EOF > ./credentials-velero [default] aws_access_key_id=<AWS_ACCESS_KEY_ID> aws_secret_access_key=<AWS_SECRET_ACCESS_KEY> EOF - $ cat << EOF > ./credentials-velero [default] aws_access_key_id=<AWS_ACCESS_KEY_ID> aws_secret_access_key=<AWS_SECRET_ACCESS_KEY> EOF- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You use the - credentials-velerofile to create a- Secretobject when you install the Data Protection Application.
4.4.6.2. About backup and snapshot locations and their secrets
						You specify backup and snapshot locations and their secrets in the DataProtectionApplication custom resource (CR).
					
Backup locations
You specify S3-compatible object storage, such as Multicloud Object Gateway or MinIO, as a backup location.
Velero backs up OpenShift Container Platform resources, Kubernetes objects, and internal images as an archive file on object storage.
Snapshot locations
If you use your cloud provider’s native snapshot API to back up persistent volumes, you must specify the cloud provider as the snapshot location.
						If you use Container Storage Interface (CSI) snapshots, you do not need to specify a snapshot location because you will create a VolumeSnapshotClass CR to register the CSI driver.
					
If you use Restic, you do not need to specify a snapshot location because Restic backs up the file system on object storage.
Secrets
						If the backup and snapshot locations use the same credentials or if you do not require a snapshot location, you create a default Secret.
					
If the backup and snapshot locations use different credentials, you create two secret objects:
- 
								Custom Secretfor the backup location, which you specify in theDataProtectionApplicationCR.
- 
								Default Secretfor the snapshot location, which is not referenced in theDataProtectionApplicationCR.
							The Data Protection Application requires a default Secret. Otherwise, the installation will fail.
						
							If you do not want to specify backup or snapshot locations during the installation, you can create a default Secret with an empty credentials-velero file.
						
4.4.6.2.1. Creating a default Secret
							You create a default Secret if your backup and snapshot locations use the same credentials or if you do not require a snapshot location.
						
							The default name of the Secret is cloud-credentials.
						
								The DataProtectionApplication custom resource (CR) requires a default Secret. Otherwise, the installation will fail. If the name of the backup location Secret is not specified, the default name is used.
							
								If you do not want to use the backup location credentials during the installation, you can create a Secret with the default name by using an empty credentials-velero file.
							
Prerequisites
- Your object storage and cloud storage, if any, must use the same credentials.
- You must configure object storage for Velero.
- 
									You must create a credentials-velerofile for the object storage in the appropriate format.
Procedure
- Create a - Secretwith the default name:- oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
							The Secret is referenced in the spec.backupLocations.credential block of the DataProtectionApplication CR when you install the Data Protection Application.
						
4.4.6.2.2. Creating secrets for different credentials
							If your backup and snapshot locations use different credentials, you must create two Secret objects:
						
- 
									Backup location Secretwith a custom name. The custom name is specified in thespec.backupLocationsblock of theDataProtectionApplicationcustom resource (CR).
- 
									Snapshot location Secretwith the default name,cloud-credentials. ThisSecretis not specified in theDataProtectionApplicationCR.
Procedure
- 
									Create a credentials-velerofile for the snapshot location in the appropriate format for your cloud provider.
- Create a - Secretfor the snapshot location with the default name:- oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Create a credentials-velerofile for the backup location in the appropriate format for your object storage.
- Create a - Secretfor the backup location with a custom name:- oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic <custom_secret> -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the - Secretwith the custom name to the- DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Backup locationSecretwith custom name.
 
4.4.6.3. Configuring the Data Protection Application
You can configure the Data Protection Application by setting Velero resource allocations or enabling self-signed CA certificates.
4.4.6.3.1. Setting Velero CPU and memory resource allocations
							You set the CPU and memory resource allocations for the Velero pod by editing the DataProtectionApplication custom resource (CR) manifest.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the values in the - spec.configuration.velero.podConfig.ResourceAllocationsblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.6.3.2. Enabling self-signed CA certificates
							You must enable a self-signed CA certificate for object storage by editing the DataProtectionApplication custom resource (CR) manifest to prevent a certificate signed by unknown authority error.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the - spec.backupLocations.velero.objectStorage.caCertparameter and- spec.backupLocations.velero.configparameters of the- DataProtectionApplicationCR manifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.6.4. Installing the Data Protection Application
						You install the Data Protection Application (DPA) by creating an instance of the DataProtectionApplication API.
					
Prerequisites
- You must install the OADP Operator.
- You must configure object storage as a backup location.
- If you use snapshots to back up PVs, your cloud provider must support either a native snapshot API or Container Storage Interface (CSI) snapshots.
- 
								If the backup and snapshot locations use the same credentials, you must create a Secretwith the default name,cloud-credentials.
- If the backup and snapshot locations use different credentials, you must create two - Secrets:- 
										Secretwith a custom name for the backup location. You add thisSecretto theDataProtectionApplicationCR.
- Secretwith the default name,- cloud-credentials, for the snapshot location. This- Secretis not referenced in the- DataProtectionApplicationCR.Note- If you do not want to specify backup or snapshot locations during the installation, you can create a default - Secretwith an empty- credentials-velerofile. If there is no default- Secret, the installation will fail.Note- Velero creates a secret named - velero-repo-credentialsin the OADP namespace, which contains a default backup repository password. You can update the secret with your own password encoded as base64 before you run your first backup targeted to the backup repository. The value of the key to update is- Data[repository-password].- After you create your DPA, the first time that you run a backup targeted to the backup repository, Velero creates a backup repository whose secret is - velero-repo-credentials, which contains either the default password or the one you replaced it with. If you update the secret password after the first backup, the new password will not match the password in- velero-repo-credentials, and therefore, Velero will not be able to connect with the older backups.
 
- 
										
Procedure
- 
								Click Operators Installed Operators and select the OADP Operator. 
- Under Provided APIs, click Create instance in the DataProtectionApplication box.
- Click YAML View and update the parameters of the - DataProtectionApplicationmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theopenshiftplugin is mandatory.
- 2
- Specify how many minutes to wait for several Velero resources before timeout occurs, such as Velero CRD availability, volumeSnapshot deletion, and backup repository availability. The default is 10m.
- 3
- Set this value tofalseif you want to disable the Restic installation. Restic deploys a daemon set, which means that Restic pods run on each working node. In OADP version 1.2 and later, you can configure Restic for backups by addingspec.defaultVolumesToFsBackup: trueto theBackupCR. In OADP version 1.1, addspec.defaultVolumesToRestic: trueto theBackupCR.
- 4
- Specify on which nodes Restic is available. By default, Restic runs on all nodes.
- 5
- Specify the URL of the S3 endpoint.
- 6
- If you do not specify this value, the default name,cloud-credentials, is used. If you specify a custom name, the custom name is used for the backup location.
- 7
- Specify a bucket as the backup storage location. If the bucket is not a dedicated bucket for Velero backups, you must specify a prefix.
- 8
- Specify a prefix for Velero backups, for example,velero, if the bucket is used for multiple purposes.
 
- Click Create.
- Verify the installation by viewing the OADP resources: - oc get all -n openshift-adp - $ oc get all -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.6.4.1. Enabling CSI in the DataProtectionApplication CR
							You enable the Container Storage Interface (CSI) in the DataProtectionApplication custom resource (CR) in order to back up persistent volumes with CSI snapshots.
						
Prerequisites
- The cloud provider must support CSI snapshots.
Procedure
- Edit the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add thecsidefault plugin.
 
4.4.7. Configuring the OpenShift API for Data Protection with OpenShift Data Foundation
You install the OpenShift API for Data Protection (OADP) with OpenShift Data Foundation by installing the OADP Operator and configuring a backup location and a snapshot location. Then, you install the Data Protection Application.
Starting from OADP 1.0.4, all OADP 1.0.z versions can only be used as a dependency of the MTC Operator and are not available as a standalone Operator.
You can configure Multicloud Object Gateway or any S3-compatible object storage as a backup location.
						The CloudStorage API, which automates the creation of a bucket for object storage, is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
					
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
					You create a Secret for the backup location and then you install the Data Protection Application. For more details, see Installing the OADP Operator.
				
To install the OADP Operator in a restricted network environment, you must first disable the default OperatorHub sources and mirror the Operator catalog. For details, see Using Operator Lifecycle Manager on restricted networks.
4.4.7.1. About backup and snapshot locations and their secrets
						You specify backup and snapshot locations and their secrets in the DataProtectionApplication custom resource (CR).
					
Backup locations
You specify S3-compatible object storage, such as Multicloud Object Gateway or MinIO, as a backup location.
Velero backs up OpenShift Container Platform resources, Kubernetes objects, and internal images as an archive file on object storage.
Snapshot locations
If you use your cloud provider’s native snapshot API to back up persistent volumes, you must specify the cloud provider as the snapshot location.
						If you use Container Storage Interface (CSI) snapshots, you do not need to specify a snapshot location because you will create a VolumeSnapshotClass CR to register the CSI driver.
					
If you use Restic, you do not need to specify a snapshot location because Restic backs up the file system on object storage.
Secrets
						If the backup and snapshot locations use the same credentials or if you do not require a snapshot location, you create a default Secret.
					
If the backup and snapshot locations use different credentials, you create two secret objects:
- 
								Custom Secretfor the backup location, which you specify in theDataProtectionApplicationCR.
- 
								Default Secretfor the snapshot location, which is not referenced in theDataProtectionApplicationCR.
							The Data Protection Application requires a default Secret. Otherwise, the installation will fail.
						
							If you do not want to specify backup or snapshot locations during the installation, you can create a default Secret with an empty credentials-velero file.
						
4.4.7.1.1. Creating a default Secret
							You create a default Secret if your backup and snapshot locations use the same credentials or if you do not require a snapshot location.
						
								The DataProtectionApplication custom resource (CR) requires a default Secret. Otherwise, the installation will fail. If the name of the backup location Secret is not specified, the default name is used.
							
								If you do not want to use the backup location credentials during the installation, you can create a Secret with the default name by using an empty credentials-velero file.
							
Prerequisites
- Your object storage and cloud storage, if any, must use the same credentials.
- You must configure object storage for Velero.
- 
									You must create a credentials-velerofile for the object storage in the appropriate format.
Procedure
- Create a - Secretwith the default name:- oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero - $ oc create secret generic cloud-credentials -n openshift-adp --from-file cloud=credentials-velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
							The Secret is referenced in the spec.backupLocations.credential block of the DataProtectionApplication CR when you install the Data Protection Application.
						
4.4.7.2. Configuring the Data Protection Application
You can configure the Data Protection Application by setting Velero resource allocations or enabling self-signed CA certificates.
4.4.7.2.1. Setting Velero CPU and memory resource allocations
							You set the CPU and memory resource allocations for the Velero pod by editing the DataProtectionApplication custom resource (CR) manifest.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the values in the - spec.configuration.velero.podConfig.ResourceAllocationsblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.7.2.1.1. Adjusting Ceph CPU and memory requirements based on collected data
The following recommendations are based on observations of performance made in the scale and performance lab. The changes are specifically related to {odf-first}. If working with {odf-short}, consult the appropriate tuning guides for official recommendations.
4.4.7.2.1.1.1. CPU and memory requirement for configurations
									Backup and restore operations require large amounts of CephFS PersistentVolumes (PVs). To avoid Ceph MDS pods restarting with an out-of-memory (OOM) error, the following configuration is suggested:
								
| Configuration types | Request | Max limit | 
|---|---|---|
| CPU | Request changed to 3 | Max limit to 3 | 
| Memory | Request changed to 8 Gi | Max limit to 128 Gi | 
4.4.7.2.2. Enabling self-signed CA certificates
							You must enable a self-signed CA certificate for object storage by editing the DataProtectionApplication custom resource (CR) manifest to prevent a certificate signed by unknown authority error.
						
Prerequisites
- You must have the OpenShift API for Data Protection (OADP) Operator installed.
Procedure
- Edit the - spec.backupLocations.velero.objectStorage.caCertparameter and- spec.backupLocations.velero.configparameters of the- DataProtectionApplicationCR manifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.7.3. Installing the Data Protection Application
						You install the Data Protection Application (DPA) by creating an instance of the DataProtectionApplication API.
					
Prerequisites
- You must install the OADP Operator.
- You must configure object storage as a backup location.
- If you use snapshots to back up PVs, your cloud provider must support either a native snapshot API or Container Storage Interface (CSI) snapshots.
- If the backup and snapshot locations use the same credentials, you must create a - Secretwith the default name,- cloud-credentials.Note- If you do not want to specify backup or snapshot locations during the installation, you can create a default - Secretwith an empty- credentials-velerofile. If there is no default- Secret, the installation will fail.Note- Velero creates a secret named - velero-repo-credentialsin the OADP namespace, which contains a default backup repository password. You can update the secret with your own password encoded as base64 before you run your first backup targeted to the backup repository. The value of the key to update is- Data[repository-password].- After you create your DPA, the first time that you run a backup targeted to the backup repository, Velero creates a backup repository whose secret is - velero-repo-credentials, which contains either the default password or the one you replaced it with. If you update the secret password after the first backup, the new password will not match the password in- velero-repo-credentials, and therefore, Velero will not be able to connect with the older backups.
Procedure
- 
								Click Operators Installed Operators and select the OADP Operator. 
- Under Provided APIs, click Create instance in the DataProtectionApplication box.
- 
								Click YAML View and update the parameters of the DataProtectionApplicationmanifest:
- Click Create.
- Verify the installation by viewing the OADP resources: - oc get all -n openshift-adp - $ oc get all -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4.7.3.1. Creating an Object Bucket Claim for disaster recovery on OpenShift Data Foundation
							If you use cluster storage for your Multicloud Object Gateway (MCG) bucket backupStorageLocation on OpenShift Data Foundation, create an Object Bucket Claim (OBC) using the OpenShift Web Console.
						
Failure to configure an Object Bucket Claim (OBC) might lead to backups not being available.
Unless specified otherwise, "NooBaa" refers to the open source project that provides lightweight object storage, while "Multicloud Object Gateway (MCG)" refers to the Red Hat distribution of NooBaa.
For more information on the MCG, see Accessing the Multicloud Object Gateway with your applications.
Procedure
- Create an Object Bucket Claim (OBC) using the OpenShift web console as described in Creating an Object Bucket Claim using the OpenShift Web Console.
4.4.7.3.2. Enabling CSI in the DataProtectionApplication CR
							You enable the Container Storage Interface (CSI) in the DataProtectionApplication custom resource (CR) in order to back up persistent volumes with CSI snapshots.
						
Prerequisites
- The cloud provider must support CSI snapshots.
Procedure
- Edit the - DataProtectionApplicationCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add thecsidefault plugin.
 
4.5. Uninstalling OADP
4.5.1. Uninstalling the OpenShift API for Data Protection
You uninstall the OpenShift API for Data Protection (OADP) by deleting the OADP Operator. See Deleting Operators from a cluster for details.
4.6. OADP backing up
4.6.1. Backing up applications
					You back up applications by creating a Backup custom resource (CR). See Creating a Backup CR.
				
					The Backup CR creates backup files for Kubernetes resources and internal images, on S3 object storage, and snapshots for persistent volumes (PVs), if the cloud provider uses a native snapshot API or the Container Storage Interface (CSI) to create snapshots, such as OpenShift Data Foundation 4.
				
For more information about CSI volume snapshots, see CSI volume snapshots.
						The CloudStorage API for S3 storage is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
					
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
- 
							If your cloud provider has a native snapshot API or supports CSI snapshots, the BackupCR backs up persistent volumes (PVs) by creating snapshots. For more information about working with CSI snapshots, see Backing up persistent volumes with CSI snapshots.
- If your cloud provider does not support snapshots or if your applications are on NFS data volumes, you can create backups by using Restic. See Backing up applications with Restic.
The OpenShift API for Data Protection (OADP) does not support backing up volume snapshots that were created by other software.
You can create backup hooks to run commands before or after the backup operation. See Creating backup hooks.
					You can schedule backups by creating a Schedule CR instead of a Backup CR. See Scheduling backups.
				
4.6.1.1. Known issues
OpenShift Container Platform 4.14 enforces a pod security admission (PSA) policy that can hinder the readiness of pods during a Restic restore process.
This issue has been resolved in the OADP 1.1.6 and OADP 1.2.2 releases, therefore it is recommended that users upgrade to these releases.
4.6.2. Creating a Backup CR
					You back up Kubernetes images, internal images, and persistent volumes (PVs) by creating a Backup custom resource (CR).
				
Prerequisites
- You must install the OpenShift API for Data Protection (OADP) Operator.
- 
							The DataProtectionApplicationCR must be in aReadystate.
- Backup location prerequisites: - You must have S3 object storage configured for Velero.
- 
									You must have a backup location configured in the DataProtectionApplicationCR.
 
- Snapshot location prerequisites: - Your cloud provider must have a native snapshot API or support Container Storage Interface (CSI) snapshots.
- 
									For CSI snapshots, you must create a VolumeSnapshotClassCR to register the CSI driver.
- 
									You must have a volume location configured in the DataProtectionApplicationCR.
 
Procedure
- Retrieve the - backupStorageLocationsCRs by entering the following command:- oc get backupStorageLocations -n openshift-adp - $ oc get backupStorageLocations -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAMESPACE NAME PHASE LAST VALIDATED AGE DEFAULT openshift-adp velero-sample-1 Available 11s 31m - NAMESPACE NAME PHASE LAST VALIDATED AGE DEFAULT openshift-adp velero-sample-1 Available 11s 31m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - BackupCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify an array of namespaces to back up.
- 2
- Optional: Specify an array of resources to include in the backup. Resources might be shortcuts (for example, 'po' for 'pods') or fully-qualified. If unspecified, all resources are included.
- 3
- Optional: Specify an array of resources to exclude from the backup. Resources might be shortcuts (for example, 'po' for 'pods') or fully-qualified.
- 4
- Specify the name of thebackupStorageLocationsCR.
- 5
- Map of {key,value} pairs of backup resources that have all of the specified labels.
- 6
- Map of {key,value} pairs of backup resources that have one or more of the specified labels.
 
- Verify that the status of the - BackupCR is- Completed:- oc get backup -n openshift-adp <backup> -o jsonpath='{.status.phase}'- $ oc get backup -n openshift-adp <backup> -o jsonpath='{.status.phase}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.6.3. Backing up persistent volumes with CSI snapshots
					You back up persistent volumes with Container Storage Interface (CSI) snapshots by editing the VolumeSnapshotClass custom resource (CR) of the cloud storage before you create the Backup CR, see CSI volume snapshots.
				
For more information see Creating a Backup CR.
Prerequisites
- The cloud provider must support CSI snapshots.
- 
							You must enable CSI in the DataProtectionApplicationCR.
Procedure
- Add the - metadata.labels.velero.io/csi-volumesnapshot-class: "true"key-value pair to the- VolumeSnapshotClassCR:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
					You can now create a Backup CR.
				
4.6.4. Backing up applications with Restic
If your cloud provider does not support snapshots or if your applications are on NFS data volumes, you can create backups by using Restic.
Restic is installed by the OADP Operator by default.
Restic integration with OADP provides a solution for backing up and restoring almost any type of Kubernetes volume. This integration is an addition to OADP’s capabilities, not a replacement for existing functionality.
					You back up Kubernetes resources, internal images, and persistent volumes with Restic by editing the Backup custom resource (CR).
				
					You do not need to specify a snapshot location in the DataProtectionApplication CR.
				
						Restic does not support backing up hostPath volumes. For more information, see additional Restic limitations.
					
Prerequisites
- You must install the OpenShift API for Data Protection (OADP) Operator.
- 
							You must not disable the default Restic installation by setting spec.configuration.restic.enabletofalsein theDataProtectionApplicationCR.
- 
							The DataProtectionApplicationCR must be in aReadystate.
Procedure
- Create the - BackupCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- AdddefaultVolumesToRestic: trueto thespecblock.
 
4.6.5. Creating backup hooks
When performing a backup, it is possible to specify one or more commands to execute in a container within a pod, based on the pod being backed up.
The commands can be configured to performed before any custom action processing (Pre hooks), or after all custom actions have been completed and any additional items specified by the custom action have been backed up.
Post hooks run after the backup.
					You create backup hooks to run commands in a container in a pod by editing the Backup custom resource (CR).
				
Procedure
- Add a hook to the - spec.hooksblock of the- BackupCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Optional: You can specify namespaces to which the hook applies. If this value is not specified, the hook applies to all namespaces.
- 2
- Optional: You can specify namespaces to which the hook does not apply.
- 3
- Currently, pods are the only supported resource that hooks can apply to.
- 4
- Optional: You can specify resources to which the hook does not apply.
- 5
- Optional: This hook only applies to objects matching the label. If this value is not specified, the hook applies to all namespaces.
- 6
- Array of hooks to run before the backup.
- 7
- Optional: If the container is not specified, the command runs in the first container in the pod.
- 8
- This is the entry point for theinitcontainer being added.
- 9
- Allowed values for error handling areFailandContinue. The default isFail.
- 10
- Optional: How long to wait for the commands to run. The default is30s.
- 11
- This block defines an array of hooks to run after the backup, with the same parameters as the pre-backup hooks.
 
4.6.6. Scheduling backups using Schedule CR
The schedule operation allows you to create a backup of your data at a specified time, defined by a Cron expression.
					You schedule backups by creating a Schedule custom resource (CR) instead of a Backup CR.
				
Leave enough time in your backup schedule for a backup to finish before another backup is created.
For example, if a backup of a namespace typically takes 10 minutes, do not schedule backups more frequently than every 15 minutes.
Prerequisites
- You must install the OpenShift API for Data Protection (OADP) Operator.
- 
							The DataProtectionApplicationCR must be in aReadystate.
Procedure
- Retrieve the - backupStorageLocationsCRs:- oc get backupStorageLocations -n openshift-adp - $ oc get backupStorageLocations -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAMESPACE NAME PHASE LAST VALIDATED AGE DEFAULT openshift-adp velero-sample-1 Available 11s 31m - NAMESPACE NAME PHASE LAST VALIDATED AGE DEFAULT openshift-adp velero-sample-1 Available 11s 31m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - ScheduleCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the status of the - ScheduleCR is- Completedafter the scheduled backup runs:- oc get schedule -n openshift-adp <schedule> -o jsonpath='{.status.phase}'- $ oc get schedule -n openshift-adp <schedule> -o jsonpath='{.status.phase}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.6.7. Deleting backups
					You can remove backup files by deleting the Backup custom resource (CR).
				
						After you delete the Backup CR and the associated object storage data, you cannot recover the deleted data.
					
Prerequisites
- 
							You created a BackupCR.
- 
							You know the name of the BackupCR and the namespace that contains it.
- You downloaded the Velero CLI tool.
- You can access the Velero binary in your cluster.
Procedure
- Choose one of the following actions to delete the - BackupCR:- To delete the - BackupCR and keep the associated object storage data, issue the following command:- oc delete backup <backup_CR_name> -n <velero_namespace> - $ oc delete backup <backup_CR_name> -n <velero_namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To delete the - BackupCR and delete the associated object storage data, issue the following command:- velero backup delete <backup_CR_name> -n <velero_namespace> - $ velero backup delete <backup_CR_name> -n <velero_namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Where: - <backup_CR_name>
- 
												Specifies the name of the Backupcustom resource.
- <velero_namespace>
- 
												Specifies the namespace that contains the Backupcustom resource.
 
 
4.6.8. About Kopia
Kopia is a fast and secure open-source backup and restore tool that allows you to create encrypted snapshots of your data and save the snapshots to remote or cloud storage of your choice.
Kopia supports network and local storage locations, and many cloud or remote storage locations, including:
- Amazon S3 and any cloud storage that is compatible with S3
- Azure Blob Storage
- Google Cloud Storage Platform
Kopia uses content-addressable storage for snapshots:
- Each snapshot is always incremental. This means that all data is uploaded once to the repository, based on file content. A file is only uploaded to the repository again if it is modified.
- Multiple copies of the same file are stored once, meaning deduplication. After moving or renaming large files, Kopia can recognize that they have the same content and does not upload them again.
4.6.8.1. OADP integration with Kopia
						OADP 1.3 supports Kopia as the backup mechanism for pod volume backup in addition to Restic. You must choose one or the other at installation by setting the uploaderType field in the DataProtectionApplication custom resource (CR). The possible values are restic or kopia. If you do not specify an uploaderType, OADP 1.3 defaults to using Kopia as the backup mechanism. The data is written to and read from a unified repository.
					
DataProtectionApplication configuration for Kopia
4.7. OADP restoring
4.7.1. Restoring applications
					You restore application backups by creating a Restore custom resource (CR). See Creating a Restore CR.
				
					You can create restore hooks to run commands in a container in a pod while restoring your application by editing the Restore (CR). See Creating restore hooks
				
4.7.1.1. Creating a Restore CR
						You restore a Backup custom resource (CR) by creating a Restore CR.
					
Prerequisites
- You must install the OpenShift API for Data Protection (OADP) Operator.
- 
								The DataProtectionApplicationCR must be in aReadystate.
- 
								You must have a Velero BackupCR.
- Adjust the requested size so the persistent volume (PV) capacity matches the requested size at backup time.
Procedure
- Create a - RestoreCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Name of theBackupCR.
- 2
- Optional: Specify an array of resources to include in the restore process. Resources might be shortcuts (for example,poforpods) or fully-qualified. If unspecified, all resources are included.
- 3
- Optional: TherestorePVsparameter can be set tofalsein order to turn off restore ofPersistentVolumesfromVolumeSnapshotof Container Storage Interface (CSI) snapshots, or from native snapshots whenVolumeSnapshotLocationis configured.
 
- Verify that the status of the - RestoreCR is- Completedby entering the following command:- oc get restore -n openshift-adp <restore> -o jsonpath='{.status.phase}'- $ oc get restore -n openshift-adp <restore> -o jsonpath='{.status.phase}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the backup resources have been restored by entering the following command: - oc get all -n <namespace> - $ oc get all -n <namespace>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Namespace that you backed up.
 
- If you use Restic to restore - DeploymentConfigobjects or if you use post-restore hooks, run the- dc-restic-post-restore.shcleanup script by entering the following command:- bash dc-restic-post-restore.sh <restore-name> - $ bash dc-restic-post-restore.sh <restore-name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- In the course of the restore process, the OADP Velero plug-ins scale down the - DeploymentConfigobjects and restore the pods as standalone pods to prevent the cluster from deleting the restored- DeploymentConfigpods immediately on restore and to allow Restic and post-restore hooks to complete their actions on the restored pods. The cleanup script removes these disconnected pods and scale any- DeploymentConfigobjects back up to the appropriate number of replicas.- Example 4.1. - dc-restic-post-restore.shcleanup script- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.7.1.2. Creating restore hooks
						You create restore hooks to run commands in a container in a pod while restoring your application by editing the Restore custom resource (CR).
					
You can create two types of restore hooks:
- An - inithook adds an init container to a pod to perform setup tasks before the application container starts.- If you restore a Restic backup, the - restic-waitinit container is added before the restore hook init container.
- 
								An exechook runs commands or scripts in a container of a restored pod.
Procedure
- Add a hook to the - spec.hooksblock of the- RestoreCR, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Optional: Array of namespaces to which the hook applies. If this value is not specified, the hook applies to all namespaces.
- 2
- Currently, pods are the only supported resource that hooks can apply to.
- 3
- Optional: This hook only applies to objects matching the label selector.
- 4
- Optional: Timeout specifies the maximum amount of time Velero waits forinitContainersto complete.
- 5
- Optional: If the container is not specified, the command runs in the first container in the pod.
- 6
- This is the entrypoint for the init container being added.
- 7
- Optional: How long to wait for a container to become ready. This should be long enough for the container to start and for any preceding hooks in the same container to complete. If not set, the restore process waits indefinitely.
- 8
- Optional: How long to wait for the commands to run. The default is30s.
- 9
- Allowed values for error handling areFailandContinue:- 
												Continue: Only command failures are logged.
- 
												Fail: No more restore hooks run in any container in any pod. The status of theRestoreCR will bePartiallyFailed.
 
- 
												
 
4.8. OADP Data Mover
4.8.1. OADP Data Mover Introduction
OADP Data Mover allows you to restore stateful applications from the store if a failure, accidental deletion, or corruption of the cluster occurs.
The OADP 1.1 Data Mover is a Technology Preview feature.
The OADP 1.2 Data Mover has significantly improved features and performances, but is still a Technology Preview feature.
The OADP Data Mover is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
- You can use OADP Data Mover to back up Container Storage Interface (CSI) volume snapshots to a remote object store. See Using Data Mover for CSI snapshots.
- You can use OADP 1.2 Data Mover to backup and restore application data for clusters that use CephFS, CephRBD, or both. See Using OADP 1.2 Data Mover with Ceph storage.
- You must perform a data cleanup after you perform a backup, if you are using OADP 1.1 Data Mover. See Cleaning up after a backup using OADP 1.1 Data Mover.
Post-migration hooks are not likely to work well with the OADP 1.3 Data Mover.
The OADP 1.1 and OADP 1.2 Data Movers use synchronous processes to back up and restore application data. Because the processes are synchronous, users can be sure that any post-restore hooks start only after the persistent volumes (PVs) of the related pods are released by the persistent volume claim (PVC) of the Data Mover.
						However, the OADP 1.3 Data Mover uses an asynchronous process. As a result of this difference in sequencing, a post-restore hook might be called before the related PVs were released by the PVC of the Data Mover. If this happens, the pod remains in Pending status and cannot run the hook. The hook attempt might time out before the pod is released, leading to a PartiallyFailed restore operation.
					
4.8.1.1. OADP Data Mover prerequisites
- You have a stateful application running in a separate namespace.
- You have installed the OADP Operator by using Operator Lifecycle Manager (OLM).
- 
								You have created an appropriate VolumeSnapshotClassandStorageClass.
- You have installed the VolSync operator using OLM.
4.8.2. Using Data Mover for CSI snapshots
The OADP Data Mover enables customers to back up Container Storage Interface (CSI) volume snapshots to a remote object store. When Data Mover is enabled, you can restore stateful applications, using CSI volume snapshots pulled from the object store if a failure, accidental deletion, or corruption of the cluster occurs.
The Data Mover solution uses the Restic option of VolSync.
Data Mover supports backup and restore of CSI volume snapshots only.
					In OADP 1.2 Data Mover VolumeSnapshotBackups (VSBs) and VolumeSnapshotRestores (VSRs) are queued using the VolumeSnapshotMover (VSM). The VSM’s performance is improved by specifying a concurrent number of VSBs and VSRs simultaneously InProgress. After all async plugin operations are complete, the backup is marked as complete.
				
The OADP 1.1 Data Mover is a Technology Preview feature.
The OADP 1.2 Data Mover has significantly improved features and performances, but is still a Technology Preview feature.
The OADP Data Mover is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
Red Hat recommends that customers who use OADP 1.2 Data Mover in order to back up and restore ODF CephFS volumes, upgrade or install OpenShift Container Platform version 4.12 or later for improved performance. OADP Data Mover can leverage CephFS shallow volumes in OpenShift Container Platform version 4.12 or later, which based on our testing, can improve the performance of backup times.
Prerequisites
- 
							You have verified that the StorageClassandVolumeSnapshotClasscustom resources (CRs) support CSI.
- You have verified that only one - VolumeSnapshotClassCR has the annotation- snapshot.storage.kubernetes.io/is-default-class: "true".Note- In OpenShift Container Platform version 4.12 or later, verify that this is the only default - VolumeSnapshotClass.
- 
							You have verified that deletionPolicyof theVolumeSnapshotClassCR is set toRetain.
- 
							You have verified that only one StorageClassCR has the annotationstorageclass.kubernetes.io/is-default-class: "true".
- 
							You have included the label velero.io/csi-volumesnapshot-class: "true"in yourVolumeSnapshotClassCR.
- You have verified that the - OADP namespacehas the annotation- oc annotate --overwrite namespace/openshift-adp volsync.backube/privileged-movers="true".Note- In OADP 1.1 the above setting is mandatory. - In OADP 1.2 the - privileged-moverssetting is not required in most scenarios. The restoring container permissions should be adequate for the Volsync copy. In some user scenarios, there may be permission errors that the- privileged-mover=- truesetting should resolve.
- You have installed the VolSync Operator by using the Operator Lifecycle Manager (OLM). Note- The VolSync Operator is required for using OADP Data Mover. 
- You have installed the OADP operator by using OLM.
Procedure
- Configure a Restic secret by creating a - .yamlfile as following:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- By default, the Operator looks for a secret named - dm-credential. If you are using a different name, you need to specify the name through a Data Protection Application (DPA) CR using- dpa.spec.features.dataMover.credentialName.
- Create a DPA CR similar to the following example. The default plugins include CSI. - Example Data Protection Application (DPA) CR - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- OADP 1.2 only.
- 2
- OADP 1.2 only. Optional: Specify the upper limit of the number of snapshots allowed to be queued for backup. The default value is 10.
- 3
- OADP 1.2 only. Optional: Specify the upper limit of the number of snapshots allowed to be queued for restore. The default value is 10.
- 4
- OADP 1.2 only. Optional: Specify the number of days, between running Restic pruning on the repository. The prune operation repacks the data to free space, but it can also generate significant I/O traffic as a part of the process. Setting this option allows a trade-off between storage consumption, from no longer referenced data, and access costs.
- 5
- OADP 1.2 only. Optional: Specify VolumeSync volume options for backup and restore.
 - The OADP Operator installs two custom resource definitions (CRDs), - VolumeSnapshotBackupand- VolumeSnapshotRestore.- Example - VolumeSnapshotBackupCRD- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example - VolumeSnapshotRestoreCRD- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- You can back up a volume snapshot by performing the following steps: - Create a backup CR: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Wait up to 10 minutes and check whether the - VolumeSnapshotBackupCR status is- Completedby entering the following commands:- oc get vsb -n <app_ns> - $ oc get vsb -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - oc get vsb <vsb_name> -n <app_ns> -o jsonpath="{.status.phase}"- $ oc get vsb <vsb_name> -n <app_ns> -o jsonpath="{.status.phase}"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - A snapshot is created in the object store was configured in the DPA. Note- If the status of the - VolumeSnapshotBackupCR becomes- Failed, refer to the Velero logs for troubleshooting.
 
- You can restore a volume snapshot by performing the following steps: - 
									Delete the application namespace and the VolumeSnapshotContentthat was created by the Velero CSI plugin.
- Create a - RestoreCR and set- restorePVsto- true.- Example - RestoreCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Wait up to 10 minutes and check whether the - VolumeSnapshotRestoreCR status is- Completedby entering the following command:- oc get vsr -n <app_ns> - $ oc get vsr -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - oc get vsr <vsr_name> -n <app_ns> -o jsonpath="{.status.phase}"- $ oc get vsr <vsr_name> -n <app_ns> -o jsonpath="{.status.phase}"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check whether your application data and resources have been restored. Note- If the status of the - VolumeSnapshotRestoreCR becomes 'Failed', refer to the Velero logs for troubleshooting.
 
- 
									Delete the application namespace and the 
4.8.3. Using OADP 1.2 Data Mover with Ceph storage
You can use OADP 1.2 Data Mover to backup and restore application data for clusters that use CephFS, CephRBD, or both.
					OADP 1.2 Data Mover leverages Ceph features that support large-scale environments. One of these is the shallow copy method, which is available for OpenShift Container Platform 4.12 and later. This feature supports backing up and restoring StorageClass and AccessMode resources other than what is found on the source persistent volume claim (PVC).
				
The CephFS shallow copy feature is a back up feature. It is not part of restore operations.
4.8.3.1. Prerequisites for using OADP 1.2 Data Mover with Ceph storage
The following prerequisites apply to all back up and restore operations of data using OpenShift API for Data Protection (OADP) 1.2 Data Mover in a cluster that uses Ceph storage:
- You have installed OpenShift Container Platform 4.12 or later.
- You have installed the OADP Operator.
- 
								You have created a secret cloud-credentialsin the namespaceopenshift-adp.
- You have installed Red Hat OpenShift Data Foundation.
- You have installed the latest VolSync Operator by using Operator Lifecycle Manager.
4.8.3.2. Defining custom resources for use with OADP 1.2 Data Mover
						When you install Red Hat OpenShift Data Foundation, it automatically creates default CephFS and a CephRBD StorageClass and VolumeSnapshotClass custom resources (CRs). You must define these CRs for use with OpenShift API for Data Protection (OADP) 1.2 Data Mover.
					
After you define the CRs, you must make several other changes to your environment before you can perform your back up and restore operations.
4.8.3.2.1. Defining CephFS custom resources for use with OADP 1.2 Data Mover
							When you install Red Hat OpenShift Data Foundation, it automatically creates a default CephFS StorageClass custom resource (CR) and a default CephFS VolumeSnapshotClass CR. You can define these CRs for use with OpenShift API for Data Protection (OADP) 1.2 Data Mover.
						
Procedure
- Define the - VolumeSnapshotClassCR as in the following example:- Example - VolumeSnapshotClassCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Define the - StorageClassCR as in the following example:- Example - StorageClassCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Must be set totrue.
 
4.8.3.2.2. Defining CephRBD custom resources for use with OADP 1.2 Data Mover
							When you install Red Hat OpenShift Data Foundation, it automatically creates a default CephRBD StorageClass custom resource (CR) and a default CephRBD VolumeSnapshotClass CR. You can define these CRs for use with OpenShift API for Data Protection (OADP) 1.2 Data Mover.
						
Procedure
- Define the - VolumeSnapshotClassCR as in the following example:- Example - VolumeSnapshotClassCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Define the - StorageClassCR as in the following example:- Example - StorageClassCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8.3.2.3. Defining additional custom resources for use with OADP 1.2 Data Mover
							After you redefine the default StorageClass and CephRBD VolumeSnapshotClass custom resources (CRs), you must create the following CRs:
						
- 
									A CephFS StorageClassCR defined to use the shallow copy feature
- 
									A Restic SecretCR
Procedure
- Create a CephFS - StorageClassCR and set the- backingSnapshotparameter set to- trueas in the following example:- Example CephFS - StorageClassCR with- backingSnapshotset to- true- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Must be set totrue.
 Important- Ensure that the CephFS - VolumeSnapshotClassand- StorageClassCRs have the same value for- provisioner.
- Configure a Restic - SecretCR as in the following example:- Example Restic - SecretCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8.3.3. Backing up and restoring data using OADP 1.2 Data Mover and CephFS storage
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up and restore data using CephFS storage by enabling the shallow copy feature of CephFS.
Prerequisites
- A stateful application is running in a separate namespace with persistent volume claims (PVCs) using CephFS as the provisioner.
- 
								The StorageClassandVolumeSnapshotClasscustom resources (CRs) are defined for CephFS and OADP 1.2 Data Mover.
- 
								There is a secret cloud-credentialsin theopenshift-adpnamespace.
4.8.3.3.1. Creating a DPA for use with CephFS storage
You must create a Data Protection Application (DPA) CR before you use the OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up and restore data using CephFS storage.
Procedure
- Verify that the - deletionPolicyfield of the- VolumeSnapshotClassCR is set to- Retainby running the following command:- oc get volumesnapshotclass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"Retention Policy: "}{.deletionPolicy}{"\n"}{end}'- $ oc get volumesnapshotclass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"Retention Policy: "}{.deletionPolicy}{"\n"}{end}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the labels of the - VolumeSnapshotClassCR are set to- trueby running the following command:- oc get volumesnapshotclass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"labels: "}{.metadata.labels}{"\n"}{end}'- $ oc get volumesnapshotclass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"labels: "}{.metadata.labels}{"\n"}{end}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the - storageclass.kubernetes.io/is-default-classannotation of the- StorageClassCR is set to- trueby running the following command:- oc get storageClass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"annotations: "}{.metadata.annotations}{"\n"}{end}'- $ oc get storageClass -A -o jsonpath='{range .items[*]}{"Name: "}{.metadata.name}{" "}{"annotations: "}{.metadata.annotations}{"\n"}{end}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a Data Protection Application (DPA) CR similar to the following example: - Example DPA CR - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- There is no default value for theenablefield. Valid values aretrueorfalse.
- 2
- Use the ResticSecretthat you created when you prepared your environment for working with OADP 1.2 Data Mover and Ceph. If you do not use your ResticSecret, the CR uses the default valuedm-credentialfor this parameter.
- 3
- There is no default value for theenablefield. Valid values aretrueorfalse.
 
4.8.3.3.2. Backing up data using OADP 1.2 Data Mover and CephFS storage
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up data using CephFS storage by enabling the shallow copy feature of CephFS storage.
Procedure
- Create a - BackupCR as in the following example:- Example - BackupCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the progress of the - VolumeSnapshotBackupCRs by completing the following steps:- To check the progress of all the - VolumeSnapshotBackupCRs, run the following command:- oc get vsb -n <app_ns> - $ oc get vsb -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To check the progress of a specific - VolumeSnapshotBackupCR, run the following command:- oc get vsb <vsb_name> -n <app_ns> -ojsonpath="{.status.phase}`- $ oc get vsb <vsb_name> -n <app_ns> -ojsonpath="{.status.phase}`- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
									Wait several minutes until the VolumeSnapshotBackupCR has the statusCompleted.
- 
									Verify that there is at least one snapshot in the object store that is given in the Restic Secret. You can check for this snapshot in your targetedBackupStorageLocationstorage provider that has a prefix of/<OADP_namespace>.
4.8.3.3.3. Restoring data using OADP 1.2 Data Mover and CephFS storage
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to restore data using CephFS storage if the shallow copy feature of CephFS storage was enabled for the back up procedure. The shallow copy feature is not used in the restore procedure.
Procedure
- Delete the application namespace by running the following command: - oc delete vsb -n <app_namespace> --all - $ oc delete vsb -n <app_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete any - VolumeSnapshotContentCRs that were created during backup by running the following command:- oc delete volumesnapshotcontent --all - $ oc delete volumesnapshotcontent --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - RestoreCR as in the following example:- Example - RestoreCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the progress of the - VolumeSnapshotRestoreCRs by doing the following:- To check the progress of all the - VolumeSnapshotRestoreCRs, run the following command:- oc get vsr -n <app_ns> - $ oc get vsr -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To check the progress of a specific - VolumeSnapshotRestoreCR, run the following command:- oc get vsr <vsr_name> -n <app_ns> -ojsonpath="{.status.phase}- $ oc get vsr <vsr_name> -n <app_ns> -ojsonpath="{.status.phase}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Verify that your application data has been restored by running the following command: - oc get route <route_name> -n <app_ns> -ojsonpath="{.spec.host}"- $ oc get route <route_name> -n <app_ns> -ojsonpath="{.spec.host}"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8.3.4. Backing up and restoring data using OADP 1.2 Data Mover and split volumes (CephFS and Ceph RBD)
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up and restore data in an environment that has split volumes, that is, an environment that uses both CephFS and CephRBD.
Prerequisites
- A stateful application is running in a separate namespace with persistent volume claims (PVCs) using CephFS as the provisioner.
- 
								The StorageClassandVolumeSnapshotClasscustom resources (CRs) are defined for CephFS and OADP 1.2 Data Mover.
- 
								There is a secret cloud-credentialsin theopenshift-adpnamespace.
4.8.3.4.1. Creating a DPA for use with split volumes
You must create a Data Protection Application (DPA) CR before you use the OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up and restore data using split volumes.
Procedure
- Create a Data Protection Application (DPA) CR as in the following example: - Example DPA CR for environment with split volumes - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Use the ResticSecretthat you created when you prepared your environment for working with OADP 1.2 Data Mover and Ceph. If you do not, then the CR will use the default valuedm-credentialfor this parameter.
- 2
- A different set ofVolumeOptionsForStorageClasslabels can be defined for eachstorageClassvolume, thus allowing a backup to volumes with different providers.
 
4.8.3.4.2. Backing up data using OADP 1.2 Data Mover and split volumes
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to back up data in an environment that has split volumes.
Procedure
- Create a - BackupCR as in the following example:- Example - BackupCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the progress of the - VolumeSnapshotBackupCRs by completing the following steps:- To check the progress of all the - VolumeSnapshotBackupCRs, run the following command:- oc get vsb -n <app_ns> - $ oc get vsb -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To check the progress of a specific - VolumeSnapshotBackupCR, run the following command:- oc get vsb <vsb_name> -n <app_ns> -ojsonpath="{.status.phase}`- $ oc get vsb <vsb_name> -n <app_ns> -ojsonpath="{.status.phase}`- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
									Wait several minutes until the VolumeSnapshotBackupCR has the statusCompleted.
- 
									Verify that there is at least one snapshot in the object store that is given in the Restic Secret. You can check for this snapshot in your targetedBackupStorageLocationstorage provider that has a prefix of/<OADP_namespace>.
4.8.3.4.3. Restoring data using OADP 1.2 Data Mover and split volumes
You can use OpenShift API for Data Protection (OADP) 1.2 Data Mover to restore data in an environment that has split volumes, if the shallow copy feature of CephFS storage was enabled for the back up procedure. The shallow copy feature is not used in the restore procedure.
Procedure
- Delete the application namespace by running the following command: - oc delete vsb -n <app_namespace> --all - $ oc delete vsb -n <app_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete any - VolumeSnapshotContentCRs that were created during backup by running the following command:- oc delete volumesnapshotcontent --all - $ oc delete volumesnapshotcontent --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - RestoreCR as in the following example:- Example - RestoreCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the progress of the - VolumeSnapshotRestoreCRs by doing the following:- To check the progress of all the - VolumeSnapshotRestoreCRs, run the following command:- oc get vsr -n <app_ns> - $ oc get vsr -n <app_ns>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To check the progress of a specific - VolumeSnapshotRestoreCR, run the following command:- oc get vsr <vsr_name> -n <app_ns> -ojsonpath="{.status.phase}- $ oc get vsr <vsr_name> -n <app_ns> -ojsonpath="{.status.phase}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Verify that your application data has been restored by running the following command: - oc get route <route_name> -n <app_ns> -ojsonpath="{.spec.host}"- $ oc get route <route_name> -n <app_ns> -ojsonpath="{.spec.host}"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8.4. Cleaning up after a backup using OADP 1.1 Data Mover
For OADP 1.1 Data Mover, you must perform a data cleanup after you perform a backup.
The cleanup consists of deleting the following resources:
- Snapshots in a bucket
- Cluster resources
- Volume snapshot backups (VSBs) after a backup procedure that is either run by a schedule or is run repetitively
4.8.4.1. Deleting snapshots in a bucket
Data Mover might leave one or more snapshots in a bucket after a backup. You can either delete all the snapshots or delete individual snapshots.
Procedure
- 
								To delete all snapshots in your bucket, delete the /<protected_namespace>folder that is specified in the Data Protection Application (DPA).spec.backupLocation.objectStorage.bucketresource.
- To delete an individual snapshot: - 
										Browse to the /<protected_namespace>folder that is specified in the DPA.spec.backupLocation.objectStorage.bucketresource.
- 
										Delete the appropriate folders that are prefixed with /<volumeSnapshotContent name>-pvcwhere<VolumeSnapshotContent_name>is theVolumeSnapshotContentcreated by Data Mover per PVC.
 
- 
										Browse to the 
4.8.4.2. Deleting cluster resources
OADP 1.1 Data Mover might leave cluster resources whether or not it successfully backs up your container storage interface (CSI) volume snapshots to a remote object store.
4.8.4.2.1. Deleting cluster resources following a successful backup and restore that used Data Mover
							You can delete any VolumeSnapshotBackup or VolumeSnapshotRestore CRs that remain in your application namespace after a successful backup and restore where you used Data Mover.
						
Procedure
- Delete cluster resources that remain on the application namespace, the namespace with the application PVCs to backup and restore, after a backup where you use Data Mover: - oc delete vsb -n <app_namespace> --all - $ oc delete vsb -n <app_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete cluster resources that remain after a restore where you use Data Mover: - oc delete vsr -n <app_namespace> --all - $ oc delete vsr -n <app_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If needed, delete any - VolumeSnapshotContentresources that remain after a backup and restore where you use Data Mover:- oc delete volumesnapshotcontent --all - $ oc delete volumesnapshotcontent --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.8.4.2.2. Deleting cluster resources following a partially successful or a failed backup and restore that used Data Mover
							If your backup and restore operation that uses Data Mover either fails or only partially succeeds, you must clean up any VolumeSnapshotBackup (VSB) or VolumeSnapshotRestore custom resource definitions (CRDs) that exist in the application namespace, and clean up any extra resources created by these controllers.
						
Procedure
- Clean up cluster resources that remain after a backup operation where you used Data Mover by entering the following commands: - Delete VSB CRDs on the application namespace, the namespace with the application PVCs to backup and restore: - oc delete vsb -n <app_namespace> --all - $ oc delete vsb -n <app_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete - VolumeSnapshotCRs:- oc delete volumesnapshot -A --all - $ oc delete volumesnapshot -A --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete - VolumeSnapshotContentCRs:- oc delete volumesnapshotcontent --all - $ oc delete volumesnapshotcontent --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete any PVCs on the protected namespace, the namespace the Operator is installed on. - oc delete pvc -n <protected_namespace> --all - $ oc delete pvc -n <protected_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete any - ReplicationSourceresources on the namespace.- oc delete replicationsource -n <protected_namespace> --all - $ oc delete replicationsource -n <protected_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Clean up cluster resources that remain after a restore operation using Data Mover by entering the following commands: - Delete VSR CRDs: - oc delete vsr -n <app-ns> --all - $ oc delete vsr -n <app-ns> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete - VolumeSnapshotCRs:- oc delete volumesnapshot -A --all - $ oc delete volumesnapshot -A --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete - VolumeSnapshotContentCRs:- oc delete volumesnapshotcontent --all - $ oc delete volumesnapshotcontent --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete any - ReplicationDestinationresources on the namespace.- oc delete replicationdestination -n <protected_namespace> --all - $ oc delete replicationdestination -n <protected_namespace> --all- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
4.9. OADP 1.3 Data Mover
4.9.1. About the OADP 1.3 Data Mover
OADP 1.3 includes a built-in Data Mover that you can use to move Container Storage Interface (CSI) volume snapshots to a remote object store. The built-in Data Mover allows you to restore stateful applications from the remote object store if a failure, accidental deletion, or corruption of the cluster occurs. It uses Kopia as the uploader mechanism to read the snapshot data and write to the unified repository.
OADP supports CSI snapshots on the following:
- Red Hat OpenShift Data Foundation
- Any other cloud storage provider with the Container Storage Interface (CSI) driver that supports the Kubernetes Volume Snapshot API
The OADP built-in Data Mover is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
4.9.1.1. Enabling the built-in Data Mover
						To enable the built-in Data Mover, you must include the CSI plugin and enable the node agent in the DataProtectionApplication custom resource (CR). The node agent is a Kubernetes daemonset that hosts data movement modules. These include the Data Mover controller, uploader, and the repository.
					
Example DataProtectionApplication manifest
4.9.1.2. Built-in Data Mover controller and custom resource definitions (CRDs)
The built-in Data Mover feature introduces three new API objects defined as CRDs for managing backup and restore:
- 
								DataDownload: Represents a data download of a volume snapshot. The CSI plugin creates oneDataDownloadobject per volume to be restored. TheDataDownloadCR includes information about the target volume, the specified Data Mover, the progress of the current data download, the specified backup repository, and the result of the current data download after the process is complete.
- 
								DataUpload: Represents a data upload of a volume snapshot. The CSI plugin creates oneDataUploadobject per CSI snapshot. TheDataUploadCR includes information about the specified snapshot, the specified Data Mover, the specified backup repository, the progress of the current data upload, and the result of the current data upload after the process is complete.
- 
								BackupRepository: Represents and manages the lifecycle of the backup repositories. OADP creates a backup repository per namespace when the first CSI snapshot backup or restore for a namespace is requested.
4.9.2. Backing up and restoring CSI snapshots
You can back up and restore persistent volumes by using the OADP 1.3 Data Mover.
4.9.2.1. Backing up persistent volumes with CSI snapshots
You can use the OADP Data Mover to back up Container Storage Interface (CSI) volume snapshots to a remote object store.
Prerequisites
- 
								You have access to the cluster with the cluster-adminrole.
- You have installed the OADP Operator.
- 
								You have included the CSI plugin and enabled the node agent in the DataProtectionApplicationcustom resource (CR).
- You have an application with persistent volumes running in a separate namespace.
- 
								You have added the metadata.labels.velero.io/csi-volumesnapshot-class: "true"key-value pair to theVolumeSnapshotClassCR.
Procedure
- Create a YAML file for the - Backupobject, as in the following example:- Example - BackupCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Set totrueto enable movement of CSI snapshots to remote object storage.
 
- Apply the manifest: - oc create -f backup.yaml - $ oc create -f backup.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - A - DataUploadCR is created after the snapshot creation is complete.
Verification
- Verify that the snapshot data is successfully transferred to the remote object store by monitoring the - status.phasefield of the- DataUploadCR. Possible values are- In Progress,- Completed,- Failed, or- Canceled. The object store is configured in the- backupLocationsstanza of the- DataProtectionApplicationCR.- Run the following command to get a list of all - DataUploadobjects:- oc get datauploads -A - $ oc get datauploads -A- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAMESPACE NAME STATUS STARTED BYTES DONE TOTAL BYTES STORAGE LOCATION AGE NODE openshift-adp backup-test-1-sw76b Completed 9m47s 108104082 108104082 dpa-sample-1 9m47s ip-10-0-150-57.us-west-2.compute.internal openshift-adp mongo-block-7dtpf Completed 14m 1073741824 1073741824 dpa-sample-1 14m ip-10-0-150-57.us-west-2.compute.internal - NAMESPACE NAME STATUS STARTED BYTES DONE TOTAL BYTES STORAGE LOCATION AGE NODE openshift-adp backup-test-1-sw76b Completed 9m47s 108104082 108104082 dpa-sample-1 9m47s ip-10-0-150-57.us-west-2.compute.internal openshift-adp mongo-block-7dtpf Completed 14m 1073741824 1073741824 dpa-sample-1 14m ip-10-0-150-57.us-west-2.compute.internal- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check the value of the - status.phasefield of the specific- DataUploadobject by running the following command:- oc get datauploads <dataupload_name> -o yaml - $ oc get datauploads <dataupload_name> -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Indicates that snapshot data is successfully transferred to the remote object store.
 
 
4.9.2.2. Restoring CSI volume snapshots
						You can restore a volume snapshot by creating a Restore CR.
					
You cannot restore Volsync backups from OADP 1.2 with the OAPD 1.3 built-in Data Mover. It is recommended to do a file system backup of all of your workloads with Restic prior to upgrading to OADP 1.3.
Prerequisites
- 
								You have access to the cluster with the cluster-adminrole.
- 
								You have an OADP BackupCR from which to restore the data.
Procedure
- Create a YAML file for the - RestoreCR, as in the following example:- Example - RestoreCR- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the manifest: - oc create -f restore.yaml - $ oc create -f restore.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - A - DataDownloadCR is created when the restore starts.
Verification
- You can monitor the status of the restore process by checking the - status.phasefield of the- DataDownloadCR. Possible values are- In Progress,- Completed,- Failed, or- Canceled.- To get a list of all - DataDownloadobjects, run the following command:- oc get datadownloads -A - $ oc get datadownloads -A- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAMESPACE NAME STATUS STARTED BYTES DONE TOTAL BYTES STORAGE LOCATION AGE NODE openshift-adp restore-test-1-sk7lg Completed 7m11s 108104082 108104082 dpa-sample-1 7m11s ip-10-0-150-57.us-west-2.compute.internal - NAMESPACE NAME STATUS STARTED BYTES DONE TOTAL BYTES STORAGE LOCATION AGE NODE openshift-adp restore-test-1-sk7lg Completed 7m11s 108104082 108104082 dpa-sample-1 7m11s ip-10-0-150-57.us-west-2.compute.internal- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Enter the following command to check the value of the - status.phasefield of the specific- DataDownloadobject:- oc get datadownloads <datadownload_name> -o yaml - $ oc get datadownloads <datadownload_name> -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Indicates that the CSI snapshot data is successfully restored.
 
 
4.10. Troubleshooting
You can debug Velero custom resources (CRs) by using the OpenShift CLI tool or the Velero CLI tool. The Velero CLI tool provides more detailed logs and information.
You can check installation issues, backup and restore CR issues, and Restic issues.
				You can collect logs and CR information by using the must-gather tool.
			
You can obtain the Velero CLI tool by:
- Downloading the Velero CLI tool
- Accessing the Velero binary in the Velero deployment in the cluster
4.10.1. Downloading the Velero CLI tool
You can download and install the Velero CLI tool by following the instructions on the Velero documentation page.
The page includes instructions for:
- macOS by using Homebrew
- GitHub
- Windows by using Chocolatey
Prerequisites
- You have access to a Kubernetes cluster, v1.16 or later, with DNS and container networking enabled.
- 
							You have installed kubectllocally.
Procedure
- Open a browser and navigate to "Install the CLI" on the Velero website.
- Follow the appropriate procedure for macOS, GitHub, or Windows.
- Download the Velero version appropriate for your version of OADP and OpenShift Container Platform.
4.10.1.1. OADP-Velero-OpenShift Container Platform version relationship
| OADP version | Velero version | OpenShift Container Platform version | 
|---|---|---|
| 1.1.0 | 4.9 and later | |
| 1.1.1 | 4.9 and later | |
| 1.1.2 | 4.9 and later | |
| 1.1.3 | 4.9 and later | |
| 1.1.4 | 4.9 and later | |
| 1.1.5 | 4.9 and later | |
| 1.1.6 | 4.11 and later | |
| 1.1.7 | 4.11 and later | |
| 1.2.0 | 4.11 and later | |
| 1.2.1 | 4.11 and later | |
| 1.2.2 | 4.11 and later | |
| 1.2.3 | 4.11 and later | 
4.10.2. Accessing the Velero binary in the Velero deployment in the cluster
You can use a shell command to access the Velero binary in the Velero deployment in the cluster.
Prerequisites
- 
							Your DataProtectionApplicationcustom resource has a status ofReconcile complete.
Procedure
- Enter the following command to set the needed alias: - alias velero='oc -n openshift-adp exec deployment/velero -c velero -it -- ./velero' - $ alias velero='oc -n openshift-adp exec deployment/velero -c velero -it -- ./velero'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.3. Debugging Velero resources with the OpenShift CLI tool
					You can debug a failed backup or restore by checking Velero custom resources (CRs) and the Velero pod log with the OpenShift CLI tool.
				
Velero CRs
					Use the oc describe command to retrieve a summary of warnings and errors associated with a Backup or Restore CR:
				
oc describe <velero_cr> <cr_name>
$ oc describe <velero_cr> <cr_name>Velero pod logs
					Use the oc logs command to retrieve the Velero pod logs:
				
oc logs pod/<velero>
$ oc logs pod/<velero>Velero pod debug logs
					You can specify the Velero log level in the DataProtectionApplication resource as shown in the following example.
				
This option is available starting from OADP 1.0.3.
					The following logLevel values are available:
				
- 
							trace
- 
							debug
- 
							info
- 
							warning
- 
							error
- 
							fatal
- 
							panic
					It is recommended to use debug for most logs.
				
4.10.4. Debugging Velero resources with the Velero CLI tool
					You can debug Backup and Restore custom resources (CRs) and retrieve logs with the Velero CLI tool.
				
The Velero CLI tool provides more detailed information than the OpenShift CLI tool.
Syntax
					Use the oc exec command to run a Velero CLI command:
				
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ <backup_restore_cr> <command> <cr_name>
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  <backup_restore_cr> <command> <cr_name>Example
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ backup describe 0e44ae00-5dc3-11eb-9ca8-df7e5254778b-2d8ql
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  backup describe 0e44ae00-5dc3-11eb-9ca8-df7e5254778b-2d8qlHelp option
					Use the velero --help option to list all Velero CLI commands:
				
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ --help
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  --helpDescribe command
					Use the velero describe command to retrieve a summary of warnings and errors associated with a Backup or Restore CR:
				
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ <backup_restore_cr> describe <cr_name>
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  <backup_restore_cr> describe <cr_name>Example
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ backup describe 0e44ae00-5dc3-11eb-9ca8-df7e5254778b-2d8ql
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  backup describe 0e44ae00-5dc3-11eb-9ca8-df7e5254778b-2d8qlLogs command
					Use the velero logs command to retrieve the logs of a Backup or Restore CR:
				
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ <backup_restore_cr> logs <cr_name>
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  <backup_restore_cr> logs <cr_name>Example
oc -n openshift-adp exec deployment/velero -c velero -- ./velero \ restore logs ccc7c2d0-6017-11eb-afab-85d0007f5a19-x4lbf
$ oc -n openshift-adp exec deployment/velero -c velero -- ./velero \
  restore logs ccc7c2d0-6017-11eb-afab-85d0007f5a19-x4lbf4.10.5. Pods crash or restart due to lack of memory or CPU
If a Velero or Restic pod crashes due to a lack of memory or CPU, you can set specific resource requests for either of those resources.
4.10.5.1. Setting resource requests for a Velero pod
						You can use the configuration.velero.podConfig.resourceAllocations specification field in the oadp_v1alpha1_dpa.yaml file to set specific resource requests for a Velero pod.
					
Procedure
- Set the - cpuand- memoryresource requests in the YAML file:- Example Velero file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- TheresourceAllocationslisted are for average usage.
 
4.10.5.2. Setting resource requests for a Restic pod
						You can use the configuration.restic.podConfig.resourceAllocations specification field to set specific resource requests for a Restic pod.
					
Procedure
- Set the - cpuand- memoryresource requests in the YAML file:- Example Restic file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- TheresourceAllocationslisted are for average usage.
 
							The values for the resource request fields must follow the same format as Kubernetes resource requirements. Also, if you do not specify configuration.velero.podConfig.resourceAllocations or configuration.restic.podConfig.resourceAllocations, the default resources specification for a Velero pod or a Restic pod is as follows:
						
requests: cpu: 500m memory: 128Mi
requests:
  cpu: 500m
  memory: 128Mi4.10.6. Issues with Velero and admission webhooks
Velero has limited abilities to resolve admission webhook issues during a restore. If you have workloads with admission webhooks, you might need to use an additional Velero plugin or make changes to how you restore the workload.
Typically, workloads with admission webhooks require you to create a resource of a specific kind first. This is especially true if your workload has child resources because admission webhooks typically block child resources.
					For example, creating or restoring a top-level object such as service.serving.knative.dev typically creates child resources automatically. If you do this first, you will not need to use Velero to create and restore these resources. This avoids the problem of child resources being blocked by an admission webhook that Velero might use.
				
4.10.6.1. Restoring workarounds for Velero backups that use admission webhooks
This section describes the additional steps required to restore resources for several types of Velero backups that use admission webhooks.
4.10.6.1.1. Restoring Knative resources
You might encounter problems using Velero to back up Knative resources that use admission webhooks.
							You can avoid such problems by restoring the top level Service resource first whenever you back up and restore Knative resources that use admission webhooks.
						
Procedure
- Restore the top level - service.serving.knavtive.dev Serviceresource:- velero restore <restore_name> \ --from-backup=<backup_name> --include-resources \ service.serving.knavtive.dev - $ velero restore <restore_name> \ --from-backup=<backup_name> --include-resources \ service.serving.knavtive.dev- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.6.1.2. Restoring IBM AppConnect resources
If you experience issues when you use Velero to a restore an IBM AppConnect resource that has an admission webhook, you can run the checks in this procedure.
Procedure
- Check if you have any mutating admission plugins of - kind: MutatingWebhookConfigurationin the cluster:- oc get mutatingwebhookconfigurations - $ oc get mutatingwebhookconfigurations- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Examine the YAML file of each kind: MutatingWebhookConfigurationto ensure that none of its rules block creation of the objects that are experiencing issues. For more information, see the official Kubernetes documentation.
- 
									Check that any spec.versionintype: Configuration.appconnect.ibm.com/v1beta1used at backup time is supported by the installed Operator.
4.10.6.2. Velero plugins returning "received EOF, stopping recv loop" message
							Velero plugins are started as separate processes. After the Velero operation has completed, either successfully or not, they exit. Receiving a received EOF, stopping recv loop message in the debug logs indicates that a plugin operation has completed. It does not mean that an error has occurred.
						
4.10.7. Installation issues
You might encounter issues caused by using invalid directories or incorrect credentials when you install the Data Protection Application.
4.10.7.1. Backup storage contains invalid directories
						The Velero pod log displays the error message, Backup storage contains invalid top-level directories.
					
Cause
The object storage contains top-level directories that are not Velero directories.
Solution
							If the object storage is not dedicated to Velero, you must specify a prefix for the bucket by setting the spec.backupLocations.velero.objectStorage.prefix parameter in the DataProtectionApplication manifest.
						
4.10.7.2. Incorrect AWS credentials
						The oadp-aws-registry pod log displays the error message, InvalidAccessKeyId: The AWS Access Key Id you provided does not exist in our records.
					
						The Velero pod log displays the error message, NoCredentialProviders: no valid providers in chain.
					
Cause
							The credentials-velero file used to create the Secret object is incorrectly formatted.
						
Solution
							Ensure that the credentials-velero file is correctly formatted, as in the following example:
						
Example credentials-velero file
[default] aws_access_key_id=AKIAIOSFODNN7EXAMPLE aws_secret_access_key=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
[default] 
aws_access_key_id=AKIAIOSFODNN7EXAMPLE 
aws_secret_access_key=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY4.10.8. OADP Operator issues
The OpenShift API for Data Protection (OADP) Operator might encounter issues caused by problems it is not able to resolve.
4.10.8.1. OADP Operator fails silently
						The S3 buckets of an OADP Operator might be empty, but when you run the command oc get po -n <OADP_Operator_namespace>, you see that the Operator has a status of Running. In such a case, the Operator is said to have failed silently because it incorrectly reports that it is running.
					
Cause
The problem is caused when cloud credentials provide insufficient permissions.
Solution
Retrieve a list of backup storage locations (BSLs) and check the manifest of each BSL for credential issues.
Procedure
- Run one of the following commands to retrieve a list of BSLs: - Using the OpenShift CLI: - oc get backupstoragelocation -A - $ oc get backupstoragelocation -A- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Using the Velero CLI: - velero backup-location get -n <OADP_Operator_namespace> - $ velero backup-location get -n <OADP_Operator_namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Using the list of BSLs, run the following command to display the manifest of each BSL, and examine each manifest for an error. - oc get backupstoragelocation -n <namespace> -o yaml - $ oc get backupstoragelocation -n <namespace> -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Example result
4.10.9. OADP timeouts
Extending a timeout allows complex or resource-intensive processes to complete successfully without premature termination. This configuration can reduce the likelihood of errors, retries, or failures.
Ensure that you balance timeout extensions in a logical manner so that you do not configure excessively long timeouts that might hide underlying issues in the process. Carefully consider and monitor an appropriate timeout value that meets the needs of the process and the overall system performance.
The following are various OADP timeouts, with instructions of how and when to implement these parameters:
4.10.9.1. Restic timeout
						timeout defines the Restic timeout. The default value is 1h.
					
						Use the Restic timeout for the following scenarios:
					
- For Restic backups with total PV data usage that is greater than 500GB.
- If backups are timing out with the following error: - level=error msg="Error backing up item" backup=velero/monitoring error="timed out waiting for all PodVolumeBackups to complete" - level=error msg="Error backing up item" backup=velero/monitoring error="timed out waiting for all PodVolumeBackups to complete"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Procedure
- Edit the values in the - spec.configuration.restic.timeoutblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.2. Velero resource timeout
						resourceTimeout defines how long to wait for several Velero resources before timeout occurs, such as Velero custom resource definition (CRD) availability, volumeSnapshot deletion, and repository availability. The default is 10m.
					
						Use the resourceTimeout for the following scenarios:
					
- For backups with total PV data usage that is greater than 1TB. This parameter is used as a timeout value when Velero tries to clean up or delete the Container Storage Interface (CSI) snapshots, before marking the backup as complete. - A sub-task of this cleanup tries to patch VSC and this timeout can be used for that task.
 
- To create or ensure a backup repository is ready for filesystem based backups for Restic or Kopia.
- To check if the Velero CRD is available in the cluster before restoring the custom resource (CR) or resource from the backup.
Procedure
- Edit the values in the - spec.configuration.velero.resourceTimeoutblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.3. Data Mover timeout
						timeout is a user-supplied timeout to complete VolumeSnapshotBackup and VolumeSnapshotRestore. The default value is 10m.
					
						Use the Data Mover timeout for the following scenarios:
					
- 
								If creation of VolumeSnapshotBackups(VSBs) andVolumeSnapshotRestores(VSRs), times out after 10 minutes.
- 
								For large scale environments with total PV data usage that is greater than 500GB. Set the timeout for 1h.
- 
								With the VolumeSnapshotMover(VSM) plugin.
- Only with OADP 1.1.x.
Procedure
- Edit the values in the - spec.features.dataMover.timeoutblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.4. CSI snapshot timeout
						CSISnapshotTimeout specifies the time during creation to wait until the CSI VolumeSnapshot status becomes ReadyToUse, before returning error as timeout. The default value is 10m.
					
						Use the CSISnapshotTimeout for the following scenarios:
					
- With the CSI plugin.
- For very large storage volumes that may take longer than 10 minutes to snapshot. Adjust this timeout if timeouts are found in the logs.
							Typically, the default value for CSISnapshotTimeout does not require adjustment, because the default setting can accommodate large storage volumes.
						
Procedure
- Edit the values in the - spec.csiSnapshotTimeoutblock of the- BackupCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.5. Velero default item operation timeout
						defaultItemOperationTimeout defines how long to wait on asynchronous BackupItemActions and RestoreItemActions to complete before timing out. The default value is 1h.
					
						Use the defaultItemOperationTimeout for the following scenarios:
					
- Only with Data Mover 1.2.x.
- To specify the amount of time a particular backup or restore should wait for the Asynchronous actions to complete. In the context of OADP features, this value is used for the Asynchronous actions involved in the Container Storage Interface (CSI) Data Mover feature.
- 
								When defaultItemOperationTimeoutis defined in the Data Protection Application (DPA) using thedefaultItemOperationTimeout, it applies to both backup and restore operations. You can useitemOperationTimeoutto define only the backup or only the restore of those CRs, as described in the following "Item operation timeout - restore", and "Item operation timeout - backup" sections.
Procedure
- Edit the values in the - spec.configuration.velero.defaultItemOperationTimeoutblock of the- DataProtectionApplicationCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.6. Item operation timeout - restore
						ItemOperationTimeout specifies the time that is used to wait for RestoreItemAction operations. The default value is 1h.
					
						Use the restore ItemOperationTimeout for the following scenarios:
					
- Only with Data Mover 1.2.x.
- 
								For Data Mover uploads and downloads to or from the BackupStorageLocation. If the restore action is not completed when the timeout is reached, it will be marked as failed. If Data Mover operations are failing due to timeout issues, because of large storage volume sizes, then this timeout setting may need to be increased.
Procedure
- Edit the values in the - Restore.spec.itemOperationTimeoutblock of the- RestoreCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.9.7. Item operation timeout - backup
						ItemOperationTimeout specifies the time used to wait for asynchronous BackupItemAction operations. The default value is 1h.
					
						Use the backup ItemOperationTimeout for the following scenarios:
					
- Only with Data Mover 1.2.x.
- 
								For Data Mover uploads and downloads to or from the BackupStorageLocation. If the backup action is not completed when the timeout is reached, it will be marked as failed. If Data Mover operations are failing due to timeout issues, because of large storage volume sizes, then this timeout setting may need to be increased.
Procedure
- Edit the values in the - Backup.spec.itemOperationTimeoutblock of the- BackupCR manifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.10. Backup and Restore CR issues
					You might encounter these common issues with Backup and Restore custom resources (CRs).
				
4.10.10.1. Backup CR cannot retrieve volume
						The Backup CR displays the error message, InvalidVolume.NotFound: The volume ‘vol-xxxx’ does not exist.
					
Cause
The persistent volume (PV) and the snapshot locations are in different regions.
Solution
- 
								Edit the value of the spec.snapshotLocations.velero.config.regionkey in theDataProtectionApplicationmanifest so that the snapshot location is in the same region as the PV.
- 
								Create a new BackupCR.
4.10.10.2. Backup CR status remains in progress
						The status of a Backup CR remains in the InProgress phase and does not complete.
					
Cause
If a backup is interrupted, it cannot be resumed.
Solution
- Retrieve the details of the - BackupCR:- oc -n {namespace} exec deployment/velero -c velero -- ./velero \ backup describe <backup>- $ oc -n {namespace} exec deployment/velero -c velero -- ./velero \ backup describe <backup>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Delete the - BackupCR:- oc delete backup <backup> -n openshift-adp - $ oc delete backup <backup> -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You do not need to clean up the backup location because a - BackupCR in progress has not uploaded files to object storage.
- 
								Create a new BackupCR.
4.10.10.3. Backup CR status remains in PartiallyFailed
						The status of a Backup CR without Restic in use remains in the PartiallyFailed phase and does not complete. A snapshot of the affiliated PVC is not created.
					
Cause
							If the backup is created based on the CSI snapshot class, but the label is missing, CSI snapshot plugin fails to create a snapshot. As a result, the Velero pod logs an error similar to the following:
						
+
time="2023-02-17T16:33:13Z" level=error msg="Error backing up item" backup=openshift-adp/user1-backup-check5 error="error executing custom action (groupResource=persistentvolumeclaims, namespace=busy1, name=pvc1-user1): rpc error: code = Unknown desc = failed to get volumesnapshotclass for storageclass ocs-storagecluster-ceph-rbd: failed to get volumesnapshotclass for provisioner openshift-storage.rbd.csi.ceph.com, ensure that the desired volumesnapshot class has the velero.io/csi-volumesnapshot-class label" logSource="/remote-source/velero/app/pkg/backup/backup.go:417" name=busybox-79799557b5-vprq
time="2023-02-17T16:33:13Z" level=error msg="Error backing up item" backup=openshift-adp/user1-backup-check5 error="error executing custom action (groupResource=persistentvolumeclaims, namespace=busy1, name=pvc1-user1): rpc error: code = Unknown desc = failed to get volumesnapshotclass for storageclass ocs-storagecluster-ceph-rbd: failed to get volumesnapshotclass for provisioner openshift-storage.rbd.csi.ceph.com, ensure that the desired volumesnapshot class has the velero.io/csi-volumesnapshot-class label" logSource="/remote-source/velero/app/pkg/backup/backup.go:417" name=busybox-79799557b5-vprqSolution
- Delete the - BackupCR:- oc delete backup <backup> -n openshift-adp - $ oc delete backup <backup> -n openshift-adp- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
								If required, clean up the stored data on the BackupStorageLocationto free up space.
- Apply label - velero.io/csi-volumesnapshot-class=trueto the- VolumeSnapshotClassobject:- oc label volumesnapshotclass/<snapclass_name> velero.io/csi-volumesnapshot-class=true - $ oc label volumesnapshotclass/<snapclass_name> velero.io/csi-volumesnapshot-class=true- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
								Create a new BackupCR.
4.10.11. Restic issues
You might encounter these issues when you back up applications with Restic.
4.10.11.1. Restic permission error for NFS data volumes with root_squash enabled
						The Restic pod log displays the error message: controller=pod-volume-backup error="fork/exec/usr/bin/restic: permission denied".
					
Cause
							If your NFS data volumes have root_squash enabled, Restic maps to nfsnobody and does not have permission to create backups.
						
Solution
							You can resolve this issue by creating a supplemental group for Restic and adding the group ID to the DataProtectionApplication manifest:
						
- 
								Create a supplemental group for Resticon the NFS data volume.
- 
								Set the setgidbit on the NFS directories so that group ownership is inherited.
- Add the - spec.configuration.restic.supplementalGroupsparameter and the group ID to the- DataProtectionApplicationmanifest, as in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the supplemental group ID.
 
- 
								Wait for the Resticpods to restart so that the changes are applied.
4.10.11.2. Restic Backup CR cannot be recreated after bucket is emptied
						If you create a Restic Backup CR for a namespace, empty the object storage bucket, and then recreate the Backup CR for the same namespace, the recreated Backup CR fails.
					
						The velero pod log displays the following error message: stderr=Fatal: unable to open config file: Stat: The specified key does not exist.\nIs there a repository at the following location?.
					
Cause
							Velero does not recreate or update the Restic repository from the ResticRepository manifest if the Restic directories are deleted from object storage. See Velero issue 4421 for more information.
						
Solution
- Remove the related Restic repository from the namespace by running the following command: - oc delete resticrepository openshift-adp <name_of_the_restic_repository> - $ oc delete resticrepository openshift-adp <name_of_the_restic_repository>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In the following error log, - mysql-persistentis the problematic Restic repository. The name of the repository appears in italics for clarity.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.12. Using the must-gather tool
					You can collect logs, metrics, and information about OADP custom resources by using the must-gather tool.
				
					The must-gather data must be attached to all customer cases.
				
Prerequisites
- 
							You must be logged in to the OpenShift Container Platform cluster as a user with the cluster-adminrole.
- 
							You must have the OpenShift CLI (oc) installed.
Procedure
- 
							Navigate to the directory where you want to store the must-gatherdata.
- Run the - oc adm must-gathercommand for one of the following data collection options:- oc adm must-gather --image=registry.redhat.io/oadp/oadp-mustgather-rhel8:v1.1 - $ oc adm must-gather --image=registry.redhat.io/oadp/oadp-mustgather-rhel8:v1.1- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The data is saved as - must-gather/must-gather.tar.gz. You can upload this file to a support case on the Red Hat Customer Portal.- oc adm must-gather --image=registry.redhat.io/oadp/oadp-mustgather-rhel8:v1.1 \ -- /usr/bin/gather_metrics_dump - $ oc adm must-gather --image=registry.redhat.io/oadp/oadp-mustgather-rhel8:v1.1 \ -- /usr/bin/gather_metrics_dump- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This operation can take a long time. The data is saved as - must-gather/metrics/prom_data.tar.gz.
4.10.12.1. Combining options when using the must-gather tool
Currently, it is not possible to combine must-gather scripts, for example specifying a timeout threshold while permitting insecure TLS connections. In some situations, you can get around this limitation by setting up internal variables on the must-gather command line, such as the following example:
oc adm must-gather --image=brew.registry.redhat.io/rh-osbs/oadp-oadp-mustgather-rhel8:1.1.1-8 -- skip_tls=true /usr/bin/gather_with_timeout <timeout_value_in_seconds>
$ oc adm must-gather --image=brew.registry.redhat.io/rh-osbs/oadp-oadp-mustgather-rhel8:1.1.1-8  -- skip_tls=true /usr/bin/gather_with_timeout <timeout_value_in_seconds>
						In this example, set the skip_tls variable before running the gather_with_timeout script. The result is a combination of gather_with_timeout and gather_without_tls.
					
The only other variables that you can specify this way are the following:
- 
								logs_since, with a default value of72h
- 
								request_timeout, with a default value of0s
4.10.13. OADP Monitoring
The OpenShift Container Platform provides a monitoring stack that allows users and administrators to effectively monitor and manage their clusters, as well as monitor and analyze the workload performance of user applications and services running on the clusters, including receiving alerts if an event occurs.
4.10.13.1. OADP monitoring setup
The OADP Operator leverages an OpenShift User Workload Monitoring provided by the OpenShift Monitoring Stack for retrieving metrics from the Velero service endpoint. The monitoring stack allows creating user-defined Alerting Rules or querying metrics by using the OpenShift Metrics query front end.
With enabled User Workload Monitoring, it is possible to configure and use any Prometheus-compatible third-party UI, such as Grafana, to visualize Velero metrics.
						Monitoring metrics requires enabling monitoring for the user-defined projects and creating a ServiceMonitor resource to scrape those metrics from the already enabled OADP service endpoint that resides in the openshift-adp namespace.
					
Prerequisites
- 
								You have access to an OpenShift Container Platform cluster using an account with cluster-adminpermissions.
- You have created a cluster monitoring config map.
Procedure
- Edit the - cluster-monitoring-config- ConfigMapobject in the- openshift-monitoringnamespace:- oc edit configmap cluster-monitoring-config -n openshift-monitoring - $ oc edit configmap cluster-monitoring-config -n openshift-monitoring- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add or enable the - enableUserWorkloadoption in the- datasection’s- config.yamlfield:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Add this option or set totrue
 
- Wait a short period of time to verify the User Workload Monitoring Setup by checking if the following components are up and running in the - openshift-user-workload-monitoringnamespace:- oc get pods -n openshift-user-workload-monitoring - $ oc get pods -n openshift-user-workload-monitoring- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify the existence of the - user-workload-monitoring-configConfigMap in the- openshift-user-workload-monitoring. If it exists, skip the remaining steps in this procedure.- oc get configmap user-workload-monitoring-config -n openshift-user-workload-monitoring - $ oc get configmap user-workload-monitoring-config -n openshift-user-workload-monitoring- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Error from server (NotFound): configmaps "user-workload-monitoring-config" not found - Error from server (NotFound): configmaps "user-workload-monitoring-config" not found- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - user-workload-monitoring-config- ConfigMapobject for the User Workload Monitoring, and save it under the- 2_configure_user_workload_monitoring.yamlfile name:- Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - 2_configure_user_workload_monitoring.yamlfile:- oc apply -f 2_configure_user_workload_monitoring.yaml - $ oc apply -f 2_configure_user_workload_monitoring.yaml configmap/user-workload-monitoring-config created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.10.13.2. Creating OADP service monitor
						OADP provides an openshift-adp-velero-metrics-svc service which is created when the DPA is configured. The service monitor used by the user workload monitoring must point to the defined service.
					
Get details about the service by running the following commands:
Procedure
- Ensure the - openshift-adp-velero-metrics-svcservice exists. It should contain- app.kubernetes.io/name=velerolabel, which will be used as selector for the- ServiceMonitorobject.- oc get svc -n openshift-adp -l app.kubernetes.io/name=velero - $ oc get svc -n openshift-adp -l app.kubernetes.io/name=velero- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE openshift-adp-velero-metrics-svc ClusterIP 172.30.38.244 <none> 8085/TCP 1h - NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE openshift-adp-velero-metrics-svc ClusterIP 172.30.38.244 <none> 8085/TCP 1h- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a - ServiceMonitorYAML file that matches the existing service label, and save the file as- 3_create_oadp_service_monitor.yaml. The service monitor is created in the- openshift-adpnamespace where the- openshift-adp-velero-metrics-svcservice resides.- Example - ServiceMonitorobject- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - 3_create_oadp_service_monitor.yamlfile:- oc apply -f 3_create_oadp_service_monitor.yaml - $ oc apply -f 3_create_oadp_service_monitor.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - servicemonitor.monitoring.coreos.com/oadp-service-monitor created - servicemonitor.monitoring.coreos.com/oadp-service-monitor created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Confirm that the new service monitor is in an Up state by using the Administrator perspective of the OpenShift Container Platform web console: - 
										Navigate to the Observe Targets page. 
- 
										Ensure the Filter is unselected or that the User source is selected and type openshift-adpin theTextsearch field.
- Verify that the status for the Status for the service monitor is Up. - Figure 4.1. OADP metrics targets 
 
- 
										Navigate to the Observe 
4.10.13.3. Creating an alerting rule
The OpenShift Container Platform monitoring stack allows to receive Alerts configured using Alerting Rules. To create an Alerting rule for the OADP project, use one of the Metrics which are scraped with the user workload monitoring.
Procedure
- Create a - PrometheusRuleYAML file with the sample- OADPBackupFailingalert and save it as- 4_create_oadp_alert_rule.yaml.- Sample - OADPBackupFailingalert- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this sample, the Alert displays under the following conditions: - There is an increase of new failing backups during the 2 last hours that is greater than 0 and the state persists for at least 5 minutes.
- 
										If the time of the first increase is less than 5 minutes, the Alert will be in a Pendingstate, after which it will turn into aFiringstate.
 
- Apply the - 4_create_oadp_alert_rule.yamlfile, which creates the- PrometheusRuleobject in the- openshift-adpnamespace:- oc apply -f 4_create_oadp_alert_rule.yaml - $ oc apply -f 4_create_oadp_alert_rule.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - prometheusrule.monitoring.coreos.com/sample-oadp-alert created - prometheusrule.monitoring.coreos.com/sample-oadp-alert created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- After the Alert is triggered, you can view it in the following ways: - In the Developer perspective, select the Observe menu.
- In the Administrator perspective under the Observe - Alerting menu, select User in the Filter box. Otherwise, by default only the Platform Alerts are displayed. - Figure 4.2. OADP backup failing alert 
 
4.10.13.4. List of available metrics
These are the list of metrics provided by the OADP together with their Types.
| Metric name | Description | Type | 
|---|---|---|
| 
										 | Number of bytes retrieved from the cache | Counter | 
| 
										 | Number of times content was retrieved from the cache | Counter | 
| 
										 | Number of times malformed content was read from the cache | Counter | 
| 
										 | Number of times content was not found in the cache and fetched | Counter | 
| 
										 | Number of bytes retrieved from the underlying storage | Counter | 
| 
										 | Number of times content could not be found in the underlying storage | Counter | 
| 
										 | Number of times content could not be saved in the cache | Counter | 
| 
										 | 
										Number of bytes retrieved using  | Counter | 
| 
										 | 
										Number of times  | Counter | 
| 
										 | 
										Number of times  | Counter | 
| 
										 | 
										Number of times  | Counter | 
| 
										 | 
										Number of bytes passed to  | Counter | 
| 
										 | 
										Number of times  | Counter | 
| 
										 | Total number of attempted backups | Counter | 
| 
										 | Total number of attempted backup deletions | Counter | 
| 
										 | Total number of failed backup deletions | Counter | 
| 
										 | Total number of successful backup deletions | Counter | 
| 
										 | Time taken to complete backup, in seconds | Histogram | 
| 
										 | Total number of failed backups | Counter | 
| 
										 | Total number of errors encountered during backup | Gauge | 
| 
										 | Total number of items backed up | Gauge | 
| 
										 | Last status of the backup. A value of 1 is success, 0. | Gauge | 
| 
										 | Last time a backup ran successfully, Unix timestamp in seconds | Gauge | 
| 
										 | Total number of partially failed backups | Counter | 
| 
										 | Total number of successful backups | Counter | 
| 
										 | Size, in bytes, of a backup | Gauge | 
| 
										 | Current number of existent backups | Gauge | 
| 
										 | Total number of validation failed backups | Counter | 
| 
										 | Total number of warned backups | Counter | 
| 
										 | Total number of CSI attempted volume snapshots | Counter | 
| 
										 | Total number of CSI failed volume snapshots | Counter | 
| 
										 | Total number of CSI successful volume snapshots | Counter | 
| 
										 | Total number of attempted restores | Counter | 
| 
										 | Total number of failed restores | Counter | 
| 
										 | Total number of partially failed restores | Counter | 
| 
										 | Total number of successful restores | Counter | 
| 
										 | Current number of existent restores | Gauge | 
| 
										 | Total number of failed restores failing validations | Counter | 
| 
										 | Total number of attempted volume snapshots | Counter | 
| 
										 | Total number of failed volume snapshots | Counter | 
| 
										 | Total number of successful volume snapshots | Counter | 
4.10.13.5. Viewing metrics using the Observe UI
						You can view metrics in the OpenShift Container Platform web console from the Administrator or Developer perspective, which must have access to the openshift-adp project.
					
Procedure
- Navigate to the Observe - Metrics page: - If you are using the Developer perspective, follow these steps: - Select Custom query, or click on the Show PromQL link.
- Type the query and click Enter.
 
- If you are using the Administrator perspective, type the expression in the text field and select Run Queries. - Figure 4.3. OADP metrics query 
 
4.11. APIs used with OADP
The document provides information about the following APIs that you can use with OADP:
- Velero API
- OADP API
4.11.1. Velero API
Velero API documentation is maintained by Velero, not by Red Hat. It can be found at Velero API types.
4.11.2. OADP API
The following tables provide the structure of the OADP API:
| Property | Type | Description | 
|---|---|---|
| 
									 | 
									Defines the list of configurations to use for  | |
| 
									 | 
									Defines the list of configurations to use for  | |
| 
									 | map [ UnsupportedImageKey ] string | 
									Can be used to override the deployed dependent images for development. Options are  | 
| 
									 | Used to add annotations to pods deployed by Operators. | |
| 
									 | Defines the configuration of the DNS of a pod. | |
| 
									 | 
									Defines the DNS parameters of a pod in addition to those generated from  | |
| 
									 | *bool | Used to specify whether or not you want to deploy a registry for enabling backup and restore of images. | 
| 
									 | Used to define the data protection application’s server configuration. | |
| 
									 | Defines the configuration for the DPA to enable the Technology Preview features. | 
Complete schema definitions for the OADP API.
| Property | Type | Description | 
|---|---|---|
| 
									 | Location to store volume snapshots, as described in Backup Storage Location. | |
| 
									 | [Technology Preview] Automates creation of a bucket at some cloud storage providers for use as a backup storage location. | 
						The bucket parameter is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
					
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
					Complete schema definitions for the type BackupLocation.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | Location to store volume snapshots, as described in Volume Snapshot Location. | 
					Complete schema definitions for the type SnapshotLocation.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | Defines the configuration for the Velero server. | |
| 
									 | Defines the configuration for the Restic server. | 
					Complete schema definitions for the type ApplicationConfig.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | [] string | Defines the list of features to enable for the Velero instance. | 
| 
									 | [] string | 
									The following types of default Velero plugins can be installed:  | 
| 
									 | Used for installation of custom Velero plugins. Default and custom plugins are described in OADP plugins | |
| 
									 | 
									Represents a config map that is created if defined for use in conjunction with the  | |
| 
									 | 
									To install Velero without a default backup storage location, you must set the  | |
| 
									 | 
									Defines the configuration of the  | |
| 
									 | 
									Velero server’s log level (use  | 
					Complete schema definitions for the type VeleroConfig.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | Name of custom plugin. | |
| 
									 | Image of custom plugin. | 
					Complete schema definitions for the type CustomPlugin.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | *bool | 
									If set to  | 
| 
									 | []int64 | 
									Defines the Linux groups to be applied to the  | 
| 
									 | 
									A user-supplied duration string that defines the Restic timeout. Default value is  | |
| 
									 | 
									Defines the configuration of the  | 
					Complete schema definitions for the type ResticConfig.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | 
									Defines the  | |
| 
									 | 
									Defines the list of tolerations to be applied to a Velero deployment or a Restic  | |
| 
									 | 
									Set specific resource  | |
| 
									 | Labels to add to pods. | 
					Complete schema definitions for the type PodConfig.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | Defines the configuration of the Data Mover. | 
					Complete schema definitions for the type Features.
				
| Property | Type | Description | 
|---|---|---|
| 
									 | 
									If set to  | |
| 
									 | 
									User-supplied Restic  | |
| 
									 | 
									A user-supplied duration string for  | 
The OADP API is more fully detailed in OADP Operator.
4.12. Advanced OADP features and functionalities
This document provides information about advanced features and functionalities of OpenShift API for Data Protection (OADP).
4.12.1. Working with different Kubernetes API versions on the same cluster
4.12.1.1. Listing the Kubernetes API group versions on a cluster
						A source cluster might offer multiple versions of an API, where one of these versions is the preferred API version. For example, a source cluster with an API named Example might be available in the example.com/v1 and example.com/v1beta2 API groups.
					
If you use Velero to back up and restore such a source cluster, Velero backs up only the version of that resource that uses the preferred version of its Kubernetes API.
						To return to the above example, if example.com/v1 is the preferred API, then Velero only backs up the version of a resource that uses example.com/v1. Moreover, the target cluster needs to have example.com/v1 registered in its set of available API resources in order for Velero to restore the resource on the target cluster.
					
Therefore, you need to generate a list of the Kubernetes API group versions on your target cluster to be sure the preferred API version is registered in its set of available API resources.
Procedure
- Enter the following command:
oc api-resources
$ oc api-resources4.12.1.2. About Enable API Group Versions
By default, Velero only backs up resources that use the preferred version of the Kubernetes API. However, Velero also includes a feature, Enable API Group Versions, that overcomes this limitation. When enabled on the source cluster, this feature causes Velero to back up all Kubernetes API group versions that are supported on the cluster, not only the preferred one. After the versions are stored in the backup .tar file, they are available to be restored on the destination cluster.
						For example, a source cluster with an API named Example might be available in the example.com/v1 and example.com/v1beta2 API groups, with example.com/v1 being the preferred API.
					
						Without the Enable API Group Versions feature enabled, Velero backs up only the preferred API group version for Example, which is example.com/v1. With the feature enabled, Velero also backs up example.com/v1beta2.
					
When the Enable API Group Versions feature is enabled on the destination cluster, Velero selects the version to restore on the basis of the order of priority of API group versions.
Enable API Group Versions is still in beta.
						Velero uses the following algorithm to assign priorities to API versions, with 1 as the top priority:
					
- Preferred version of the destination cluster
- Preferred version of the source_ cluster
- Common non-preferred supported version with the highest Kubernetes version priority
4.12.1.3. Using Enable API Group Versions
You can use Velero’s Enable API Group Versions feature to back up all Kubernetes API group versions that are supported on a cluster, not only the preferred one.
Enable API Group Versions is still in beta.
Procedure
- 
								Configure the EnableAPIGroupVersionsfeature flag:
4.12.2. Backing up data from one cluster and restoring it to another cluster
4.12.2.1. About backing up data from one cluster and restoring it on another cluster
OpenShift API for Data Protection (OADP) is designed to back up and restore application data in the same OpenShift Container Platform cluster. Migration Toolkit for Containers (MTC) is designed to migrate containers, including application data, from one OpenShift Container Platform cluster to another cluster.
You can use OADP to back up application data from one OpenShift Container Platform cluster and restore it on another cluster. However, doing so is more complicated than using MTC or using OADP to back up and restore on the same cluster.
To successfully use OADP to back up data from one cluster and restore it to another cluster, you must take into account the following factors, in addition to the prerequisites and procedures that apply to using OADP to back up and restore data on the same cluster:
- Operators
- Use of Velero
- UID and GID ranges
4.12.2.1.1. Operators
You must exclude Operators from the backup of an application for backup and restore to succeed.
4.12.2.1.2. Use of Velero
Velero, which OADP is built upon, does not natively support migrating persistent volume snapshots across cloud providers. To migrate volume snapshot data between cloud platforms, you must either enable the Velero Restic file system backup option, which backs up volume contents at the file system level, or use the OADP Data Mover for CSI snapshots.
								In OADP 1.1 and earlier, the Velero Restic file system backup option is called restic. In OADP 1.2 and later, the Velero Restic file system backup option is called file-system-backup.
							
- You must also use Velero’s File System Backup to migrate data between AWS regions or between Microsoft Azure regions.
- Velero does not support restoring data to a cluster with an earlier Kubernetes version than the source cluster.
- It is theoretically possible to migrate workloads to a destination with a later Kubernetes version than the source, but you must consider the compatibility of API groups between clusters for each custom resource. If a Kubernetes version upgrade breaks the compatibility of core or native API groups, you must first update the impacted custom resources.
4.12.2.2. About determining which pod volumes to back up
Before you start a backup operation by using File System Backup (FSB), you must specify which pods contain a volume that you want to back up. Velero refers to this process as "discovering" the appropriate pod volumes.
Velero supports two approaches for determining pod volumes:
- Opt-in approach: The opt-in approach requires that you actively indicate that you want to include - opt-in - a volume in a backup. You do this by labelling each pod that contains a volume to be backed up with the name of the volume. When Velero finds a persistent volume (PV), it checks the pod that mounted the volume. If the pod is labelled with the name of the volume, Velero backs up the pod.
- Opt-out approach: With the opt-out approach, you must actively specify that you want to exclude a volume from a backup. You do this by labelling each pod that contains a volume you do not want to back up with the name of the volume. When Velero finds a PV, it checks the pod that mounted the volume. If the pod is labelled with the volume’s name, Velero does not back up the pod.
4.12.2.2.1. Limitations
- 
									FSB does not support backing up and restoring hostpathvolumes. However, FSB does support backing up and restoring local volumes.
- Velero uses a static, common encryption key for all backup repositories it creates. This static key means that anyone who can access your backup storage can also decrypt your backup data. It is essential that you limit access to backup storage.
- For PVCs, every incremental backup chain is maintained across pod reschedules. - For pod volumes that are not PVCs, such as - emptyDirvolumes, if a pod is deleted or recreated, for example, by a- ReplicaSetor a deployment, the next backup of those volumes will be a full backup and not an incremental backup. It is assumed that the lifecycle of a pod volume is defined by its pod.
- Even though backup data can be kept incrementally, backing up large files, such as a database, can take a long time. This is because FSB uses deduplication to find the difference that needs to be backed up.
- FSB reads and writes data from volumes by accessing the file system of the node on which the pod is running. For this reason, FSB can only back up volumes that are mounted from a pod and not directly from a PVC. Some Velero users have overcome this limitation by running a staging pod, such as a BusyBox or Alpine container with an infinite sleep, to mount these PVC and PV pairs before performing a Velero backup..
- 
									FSB expects volumes to be mounted under <hostPath>/<pod UID>, with<hostPath>being configurable. Some Kubernetes systems, for example, vCluster, do not mount volumes under the<pod UID>subdirectory, and VFSB does not work with them as expected.
4.12.2.2.2. Backing up pod volumes by using the opt-in method
							You can use the opt-in method to specify which volumes need to be backed up by File System Backup (FSB). You can do this by using the backup.velero.io/backup-volumes command.
						
Procedure
- On each pod that contains one or more volumes that you want to back up, enter the following command: - oc -n <your_pod_namespace> annotate pod/<your_pod_name> \ backup.velero.io/backup-volumes=<your_volume_name_1>, \ <your_volume_name_2>>,...,<your_volume_name_n> - $ oc -n <your_pod_namespace> annotate pod/<your_pod_name> \ backup.velero.io/backup-volumes=<your_volume_name_1>, \ <your_volume_name_2>>,...,<your_volume_name_n>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - where: - <your_volume_name_x>
- specifies the name of the xth volume in the pod specification.
 
4.12.2.2.3. Backing up pod volumes by using the opt-out method
When using the opt-out approach, all pod volumes are backed up by using File System Backup (FSB), although there are some exceptions:
- Volumes that mount the default service account token, secrets, and configuration maps.
- 
									hostPathvolumes
							You can use the opt-out method to specify which volumes not to back up. You can do this by using the backup.velero.io/backup-volumes-excludes command.
						
Procedure
- On each pod that contains one or more volumes that you do not want to back up, run the following command: - oc -n <your_pod_namespace> annotate pod/<your_pod_name> \ backup.velero.io/backup-volumes-excludes=<your_volume_name_1>, \ <your_volume_name_2>>,...,<your_volume_name_n> - $ oc -n <your_pod_namespace> annotate pod/<your_pod_name> \ backup.velero.io/backup-volumes-excludes=<your_volume_name_1>, \ <your_volume_name_2>>,...,<your_volume_name_n>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - where: - <your_volume_name_x>
- specifies the name of the xth volume in the pod specification.
 
								You can enable this behavior for all Velero backups by running the velero install command with the --default-volumes-to-fs-backup flag.
							
4.12.2.3. UID and GID ranges
If you back up data from one cluster and restore it to another cluster, problems might occur with UID (User ID) and GID (Group ID) ranges. The following section explains these potential issues and mitigations:
- Summary of the issues
- The namespace UID and GID ranges might change depending on the destination cluster. OADP does not back up and restore OpenShift UID range metadata. If the backed up application requires a specific UID, ensure the range is availableupon restore. For more information about OpenShift’s UID and GID ranges, see A Guide to OpenShift and UIDs.
- Detailed description of the issues
- When you create a namespace in OpenShift Container Platform by using the shell command - oc create namespace, OpenShift Container Platform assigns the namespace a unique User ID (UID) range from its available pool of UIDs, a Supplemental Group (GID) range, and unique SELinux MCS labels. This information is stored in the- metadata.annotationsfield of the cluster. This information is part of the Security Context Constraints (SCC) annotations, which comprise of the following components:- 
											openshift.io/sa.scc.mcs
- 
											openshift.io/sa.scc.supplemental-groups
- 
											openshift.io/sa.scc.uid-range
 
- 
											
						When you use OADP to restore the namespace, it automatically uses the information in metadata.annotations without resetting it for the destination cluster. As a result, the workload might not have access to the backed up data if any of the following is true:
					
- There is an existing namespace with other SCC annotations, for example, on another cluster. In this case, OADP uses the existing namespace during the backup instead of the namespace you want to restore.
- A label selector was used during the backup, but the namespace in which the workloads are executed does not have the label. In this case, OADP does not back up the namespace, but creates a new namespace during the restore that does not contain the annotations of the backed up namespace. This results in a new UID range being assigned to the namespace. - This can be an issue for customer workloads if OpenShift Container Platform assigns a pod a - securityContextUID to a pod based on namespace annotations that have changed since the persistent volume data was backed up.
- The UID of the container no longer matches the UID of the file owner.
- An error occurs because OpenShift Container Platform has not changed the UID range of the destination cluster to match the backup cluster data. As a result, the backup cluster has a different UID than the destination cluster, which means that the application cannot read or write data on the destination cluster. - Mitigations
- You can use one or more of the following mitigations to resolve the UID and GID range issues:
 
- Simple mitigations: - 
										If you use a label selector in the BackupCR to filter the objects to include in the backup, be sure to add this label selector to the namespace that contains the workspace.
- Remove any pre-existing version of a namespace on the destination cluster before attempting to restore a namespace with the same name.
 
- 
										If you use a label selector in the 
- Advanced mitigations: - Fix UID ranges after migration by Resolving overlapping UID ranges in OpenShift namespaces after migration. Step 1 is optional.
 
For an in-depth discussion of UID and GID ranges in OpenShift Container Platform with an emphasis on overcoming issues in backing up data on one cluster and restoring it on another, see A Guide to OpenShift and UIDs.
4.12.2.4. Backing up data from one cluster and restoring it to another cluster
In general, you back up data from one OpenShift Container Platform cluster and restore it on another OpenShift Container Platform cluster in the same way that you back up and restore data to the same cluster. However, there are some additional prerequisites and differences in the procedure when backing up data from one OpenShift Container Platform cluster and restoring it on another.
Prerequisites
- All relevant prerequisites for backing up and restoring on your platform (for example, AWS, Microsoft Azure, GCP, and so on), especially the prerequisites for the Data Protection Application (DPA), are described in the relevant sections of this guide.
Procedure
- Make the following additions to the procedures given for your platform: - Ensure that the backup store location (BSL) and volume snapshot location have the same names and paths to restore resources to another cluster.
- Share the same object storage location credentials across the clusters.
- For best results, use OADP to create the namespace on the destination cluster.
- If you use the Velero - file-system-backupoption, enable the- --default-volumes-to-fs-backupflag for use during backup by running the following command:- velero backup create <backup_name> --default-volumes-to-fs-backup <any_other_options> - $ velero backup create <backup_name> --default-volumes-to-fs-backup <any_other_options>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
							In OADP 1.2 and later, the Velero Restic option is called file-system-backup.
						
 
     
    