A typical and mandatory functionality when offering data services is the ability to do backups of your data. As there are a lot of commercial backup tools out there, the intention of this framework is not to replace them, but instead to provide and alternative way of enabling a customized backup experience.
The architecture is based on some fundamental aspects we believe are the best for a good backup strategy
- A fully usable REST API for managing the backup conditions
- File Endpoints
- Backup Plans
- Restore Points
- Backup Jobs
- Restore Jobs
- An Agent, which needs to be included on the corresponding deployment. The agent enables the OSB Backup
Manager Framework to work with deployments on any kind of deployments
- VMs
- Container
- Dedicated and Shared Cluster
- A set of Shell Scripts, which are called by the the OSB Backup Manager and enables database administrators to provide the best suitable backup strategy/implementation for an endpoint.
In the last two years we have gained substantial experience in the OSBAPI enviroment, which is a framework designed to provision Services (e.g. Database, Queueing etc.) for applications being deployed on Kubernetes or Cloud Foundry.
What we have experienced in those environments is that customers/developers do have the need for an automated backup mechanism, while on the other side DBAs (QA aka Queueing Administrators) have a quite good toolset to do most suitable backup for a platform/usecase.
With the generic architecture of the OSB Backup Manager Framework we want to enable and encourage DBAs, QAs and others to merge the best of both worlds:
- Their experience regarding the best backup technology on the platform
- The generic framework invoking the backup scheduling/backup calls and data transfer to a blockstorage
The following sections describe the core facts of the Framework, including implemented Datatransfer endpoints, features of backup plans and the scripts, which need to be implemented by the DBAs.
- S3
- Swift
- Pausing/Unpausing plans
- Compression
- Encryption
- Frequeny (based on CRON expressions)
- Retention Period
- Retention Type (based on DAYS, HOURS, FILES)
The scripts being called by the OSB Backup Manger in a backup/restore run are as follows.
The agent runs following shell scripts from top to bottom
- pre-backup-lock
- pre-backup-check
- backup
- backup-cleanup
- post-backup-unlock
In the backup stage, after the script generated the file to upload (name consists of YYYY_MM_DD.tar.gz), the agent uploads the backup file from the set directory to the cloud storage using the given information and credentials.
The agent runs following shell scripts from top to bottom
- pre-restore-lock
- restore
- restore-cleanup
- post-restore-unlock
In the restore stage, before the dedicated script starts the actual restore, the agent downloads the backed up restore file from the cloud storage, using the given information and credentials, and puts it in the dedicated directory.
osb-backup-agent GitHub
Documentation on how to set up a local dev environment (evoila specific) and the Backup Manager can be found here.
When contributing to this repository, please first discuss the change you wish to make via issue, email, or any other method with us before making a change.
- Ensure any install or build dependencies are removed before the end of the layer when doing a build.
- You may merge the Pull Request in once you have the sign-off of two other developers, or if you do not have permission to do that, you may request the second reviewer to merge it for you.
Yannic Remmet, evoila GmbH GitHub Profile.
Marius Berger, evoila GmbH GitHub Profile.
Johannes Hiemer, evoila GmbH GitHub Profile.