Back up GitLab running in a Docker container
Tier: Free, Premium, Ultimate
Offering: Self-managed
You can create a GitLab backup with:
docker exec -t <container name> gitlab-backup create
Read more on how to back up and restore GitLab.
If configuration is provided entirely via the
GITLAB_OMNIBUS_CONFIG
environment variable
(per the “Pre-configure Docker Container” steps),
meaning no configuration is set directly in the gitlab.rb
file, then there is no need
to back up the gitlab.rb
file.
Backing up the GitLab secrets file is required
to avoid complicated steps when recovering
GitLab from backup. The secrets file is stored at
/etc/gitlab/gitlab-secrets.json
inside the container, or
$GITLAB_HOME/config/gitlab-secrets.json
on the container host.Create a database backup
Before upgrading GitLab, you should create a database-only backup. If you encounter issues during the GitLab upgrade, you can restore the database backup to roll back the upgrade. To create a database backup, run this command:
docker exec -t <container name> gitlab-backup create SKIP=artifacts,repositories,registry,uploads,builds,pages,lfs,packages,terraform_state
The backup is written to /var/opt/gitlab/backups
which should be on a
volume mounted by Docker.
For more information on using the backup to roll back an upgrade, see Downgrade GitLab.