You have a number of options for disaster recovery with Application Service Adapter. This topic describes your disaster recovery options.
You have a range of approaches for ensuring you can recover your Application Service Adapter deployment, apps, and data in case of a disaster. These approaches fall into two categories:
- Backing up cluster and container image registry state and restoring from backups.
- Re-creating the data in the deployment by automating the creation of state. This is achieved using scripted CI automation of the cf CLI and applying declarative Application Service Adapter resources to the cluster.
This topic focuses on the first approach by outlining where Application Service Adapter stores state and suggestions for backing up.
In contrast to Tanzu Application Service, Application Service Adapter has no dedicated databases or blobstore. Instead, state is stored in two places:
- As Kubernetes custom resources in the Kubernetes API. These custom resources are persisted in the cluster's etcd datastore.
- As container images in an OCI compatible registry, such as a self-hosted Harbor, DockerHub, or IaaS provided registry.
To help illustrate this, consider the following scenarios.
Tanzu Application Service operators are familiar with backing up their Ops Manager and BOSH Director databases to safeguard their installation configuration. For Application Service Adapter, this works differently. Application Service Adapter is installed using the tanzu package install
command. This causes the creation of a variety of Carvel package installation resources and ConfigMaps
on the cluster which are managed by kapp-controller
. These installation resources are stored in the Kubernetes API as custom resources, which are ultimately stored in etcd.
Tanzu Application Service stores Cloud Foundry API state and application configuration across a number of databases, with the majority of it held within the Cloud Controller API's CCDB database. Application Service Adapter does not maintain its own datastore for this purpose, but instead represents all Cloud Foundry resources as Kubernetes custom resources. These custom resources are managed by the Kubernetes API and stored in etcd.
Application Service Adapter converts application source code into single-layer OCI images that are stored in the registry specified at installation.
Tanzu Application Service operators can be familiar with the concept of droplets, or TAR files representing staged apps that are ready to run on the platform. Rather than TAS-style droplets, Application Service Adapter, using Tanzu Build Service, produces runnable container images that are stored in the registry specified at installation.
VMware recommends that operators take frequent backups of both the Kubernetes cluster's etcd and the registry using open source tools such as Velero or the native backup function provided by their infrastructure platform.