Skip to content

Backups

Scheduled database backups could be configured for PostgreSQL and for Coolify itself.

This schedules are based on cron expressions, so you can configure them to run as often as you want.

You can also use simple cron expressions like:

js
const VALID_CRON_STRINGS = [
    'every_minute' => '* * * * *',
    'hourly' => '0 * * * *',
    'daily' => '0 0 * * *',
    'weekly' => '0 0 * * 0',
    'monthly' => '0 0 1 * *',
    'yearly' => '0 0 1 1 *',
];

PostgreSQL

Coolify creates a full backup of your PostgreSQL databases. You can specify which database to backup, with a comma separated list.

Backup command

bash
pg_dump --format=custom --no-acl --no-owner --username <username> <databaseName>

Restore command

The backup has custom format, so you can restore it using the following command (or with any equivalent tool):

bash
pg_restore --verbose --clean -h localhost -U postgres -d postgres pg-dump-postgres-1697207547.dmp

MySQL

bash
mysqldump -u root -p <password> <datatabaseName>

MariaDB

bash
mariadb-dump -u root -p <password> <datatabaseName>

MongoDB

bash
mongodump --authenticationDatabase=admin --uri=<uri> --gzip --archive=<archive>

Or if you exclude some collections:

bash
mongodump --authenticationDatabase=admin --uri=<uri> --gzip --archive=<archive> --excludeCollection=<collectionName> --excludeCollection=<collectionName>

S3 Backups

You can also define your own S3 compatible storage to store your backups.