KubeBackup is a tool for backing up the configuration files in a Kubernetes cluster and uploading them to a S3 bucket.
KubeBackup accesses the Kubernetes API from inside a container. Inside that container, a script exports all the cluster and namespace yaml files. These files can be used to redeploy an environment. All the exported yaml files are compressed and uploaded to an S3 Bucket.
helm repo add SupportTools https://charts.support.tools
helm repo update
helm upgrade --install kubebackup SupportTools/kubebackup \
--set s3.region="us-east-2" \
--set s3.bucket="my-bucket" \
--set s3.folder="my-cluster" \
--set s3.accessKey="S3_ACCESS_KEY_GOES_HERE" \
--set s3.secretKey="S3_SECRET_KEY_GOES_HERE"
KubeBackup is a helm chart that deploys a pod. This will take a YAML backup of your cluster and upload it to an S3 bucket.
The script connects to the Kubernetes API using either the provided kubeconfig file or the in-cluster configuration, if available. It then retrieves the list of available API resources and iterates through them to fetch namespaced and cluster-scoped objects.
Namespaced objects are grouped by namespace and saved in the namespace-scoped/<namespace>/<object>
directory, while cluster-scoped objects are saved in the cluster-scoped/<object>
directory. The output files are named .yaml.
The following table lists the configurable parameters of the KubeBackup chart and their default values.
Environment Variable | Description | Default Value |
---|---|---|
DEBUG |
Enable debug mode | false |
LOG_LEVEL |
Logging level (e.g., info , debug ) |
info |
KUBECONFIG |
Path to Kubernetes config | ~/.kube/config |
BACKUP_DIR |
Directory for storing backups temporarily | /tmp |
BACKUP_INTERVAL |
Backup interval in seconds | 12 |
RETENTION |
Retention period in days for backups in S3 | 30 |
S3_BUCKET |
S3 bucket name | |
S3_FOLDER |
Folder path within the S3 bucket | |
S3_ACCESS_KEY_ID |
S3 access key | |
S3_SECRET_ACCESS_KEY |
S3 secret key | |
S3_REGION |
S3 region | |
S3_ENDPOINT |
Custom S3 endpoint | |
S3_DISABLE_SSL |
Disable SSL verification (true or false ) |
false |
S3_CUSTOM_CA_PATH |
Path to custom CA certificate file | |
METRICS_PORT |
Metrics server port | 9000 |
To build the script from source, you will need to have the following installed:
To build the script, run the following commands:
git clone
cd kubebackup
make build
If you would like to contribute to this project, please fork the repo and submit a pull request.
This project is licensed under the Apache License - see the LICENSE file for details.