Backing Up Your UniLink Installation
Backups are crucial for any software system, including UniLink, for several reasons:
Disaster Recovery: Backups serve as your safety net in the event of catastrophic incidents like hardware failure, data center outage, or natural disasters. They allow you to restore your application to its previous state quickly.
Data Loss Prevention: Accidental data deletion or alteration due to human errors, software bugs, or malicious attacks can lead to significant losses. Backups provide a way to recover such lost or corrupted data.
Audit and Compliance: Certain regulations require businesses to maintain backups for a specific period. These backups may serve as reference points for audits or compliance checks.
Business Continuity: In situations where your primary data source becomes unavailable, having a backup allows your business to continue its operations with minimal disruption.
In short, backups are an essential part of risk management and ensure the smooth operation of your software system.
What Data Should Be Backed Up?
- Postgres Database
- Storage (File uploads/Other Assets in Your Installation)
- Configuration Variables
- Code Customisations
Postgres Database
If you are managing the Postgres service yourself, you can use the pg_dump
tool provided by PostgreSQL for this purpose.
pg_dump -U postgres -W -F t chatwoot_production > backup.tar
If you are using a managed provider like AWS, Google Cloud, or Azure, enable backups using the options provided by your provider.
Storage
Based on your storage configuration, you should take the appropriate steps.
If you are using a managed provider like S3
, GCS
, etc., ensure backups using the options available with the provider.
If you are using the local
storage provider, ensure to take a disk backup of the storage
folder in the root of your UniLink Installation.
Configuration
Important configuration might be stored in environment variables. You should back these up as well.
Make a copy of the .env
file or keep a backup of these configurations based on your setup.
Code Customisations
Official UniLink updates using tools like cwctl
assume that there are no customisations done to the UniLink installation. We don't provide support for custom modifications of the UniLink codebase. If you are planning any such modifications, please ensure that you back up these customisations using git
or other appropriate tooling.
Guidelines
The frequency of backups largely depends on the nature of your application and the amount of data you generate and can afford to lose. You can opt for continuous
or daily
backups as per your need.
Remember, these backups should be stored in a different physical location to protect against hardware failures. Using a cloud storage provider could be a good solution. Please ensure that access to these backups is tightly controlled, as they contain sensitive data.
Restoring a Backup
To restore a backup into a new UniLink installation, please follow these steps:
- Set up a new UniLink installation and finish the onboarding flow.
- Ensure that the configuration values match the ones in your backup.
- Purge the database of this installation and replace it with the data from your postgres backup.
- Restore Storage with your backup data.
- Restore any Code Customisations.
- Restart UniLink services and you are good to go.