Reference
PachCTL

Backup & Restore Your Cluster

Learn how to back-up and restore the state of a production cluster.

May 26, 2023

This page will walk you through the main steps required to manually back up and restore the state of a Pachyderm cluster in production.

Details on how to perform those steps might vary depending on your infrastructure and cloud provider / on-premises setup.

Refer to your provider’s documentation.

Overview #

Pachyderm state is stored in two main places (See our high-level architecture diagram):

Backing up a Pachyderm cluster involves snapshotting both the object store and the PostgreSQL database(s) (see above), in a consistent state, at a given point in time.

Restoring it involves re-populating the database(s) and the object store using those backups, then recreating a Pachyderm cluster.

โ„น๏ธ
  • Make sure that you have a bucket for backup use, separate from the object store used by your cluster.
  • Depending on the reasons behind your cluster recovery, you might choose to use an existing vs. a new instance of PostgreSQL and/or the object store.

Manual Back Up Of A Pachyderm Cluster #

Before any manual backup:

โ„น๏ธ
  • Backups incur downtime until operations are resumed.
  • Operational best practices include notifying Pachyderm users of the outage and providing an estimated time when downtime will cease.
  • Downtime duration is a function of the size of the data be to backed up and the networks involved; Testing before going into production and monitoring backup times on an ongoing basis might help make accurate predictions.

Suspend Operations #

โš ๏ธ

Before starting, make sure that your context points to the server you want to pause by running pachctl config get active-context. Find more information on how to set your context in our deployment section.

To pause Pachyderm:

Back Up The Databases And The Object Store #

This step is specific to your database and object store hosting.

โš ๏ธ

A production setting of Pachyderm implies that you are running a managed PostgreSQL instance.

๐Ÿ“–

For on-premises Kubernetes deployments, check the vendor documentation for your on-premises PostgreSQL for details on backing up and restoring your databases.

๐Ÿ“–

For on-premises Kubernetes deployments, check the vendor documentation for your on-premises object store for details on backing up and restoring a bucket.

Resuming operations #

Once your backup is completed, resume your normal operations by scaling pachd back up. It will take care of restoring the worker pods:

Restore Pachyderm #

There are two primary use cases for restoring a cluster:

  1. Your data have been corrupted, preventing your cluster from functioning correctly. You want the same version of Pachyderm re-installed on the latest uncorrupted data set.
  2. You have upgraded a cluster and are encountering problems. You decide to uninstall the current version and restore the latest backup of a previous version of Pachyderm.

Depending on your scenario, pick all or a subset of the following steps:

๐Ÿ“–

Find the detailed installations instructions of your PostgreSQL instance, bucket, Kubernetes cluster, permissions setup, and Pachyderm deployment for each Cloud Provider in the Deploy section of our Documentation

Restore The Databases And Objects #

Deploy Pachyderm Into The New Cluster #

Finally, update the copy of your original Helm values to point Pachyderm to the new databases and the new object store, then use Helm to install Pachyderm into the new cluster.

๐Ÿ“–

The values needing an update and deployment instructions are detailed in the Chapter 6 of all our cloud installation pages. For example, in the case of GCP, check the deploy Pachyderm chapter

Connect ‘pachctl’ To Your Restored Cluster #

…and check that your cluster is up and running.

Backup/Restore A Stand-Alone Enterprise Server #

Backing up / restoring an Enterprise Server is similar to the back up / restore of a regular cluster (see above), with two slight variations:

  1. The name of its Kubernetes deployment is pach-enterprise versus pachd in the case of a regular cluster.
  2. The Enterprise Server does not use an Object Store.
  3. An Enterprise server only requires a dex database.

Backup A Standalone Enterprise Server #

โš ๏ธ

Make sure that pachctl and kubectl are pointing to the right cluster. Check your Enterprise Server context: pachctl config get active-enterprise-context, or pachctl config set active-enterprise-context <my-enterprise-context-name> --overwrite to set it.

โ„น๏ธ

kubectl users: There is a difference with the pause of a regular cluster. The deployment of the enterprise server is named pach-enterprise; therefore, the first command should be:

kubectl scale deployment pach-enterprise --replicas 0 

There is no need to pause all the Pachyderm clusters registered to the Enterprise Server to backup the enterprise server; however, pausing the Enterprise server will result in your clusters becoming unavailable.

Restore An Enterprise Server #

Additional Info #

For additional questions about backup / restore, you can post them in the community #help channel on Slack, or reach out to your TAM if you are an Enterprise customer.