Skip to content

Instantly share code, notes, and snippets.

@FlorianHeigl
Last active March 9, 2025 17:40
Show Gist options
  • Save FlorianHeigl/da9a4e9090f31402523cde3cb81312ac to your computer and use it in GitHub Desktop.
Save FlorianHeigl/da9a4e9090f31402523cde3cb81312ac to your computer and use it in GitHub Desktop.
mediocre netbox docker backup favorable over the undecided nothing that is in place
#! /usr/bin/env bash
set -eu
. ../netbox-docker/env/postgres.env
_date=$(date +%Y%m%d%H%M)
backupdir=/backup/netbox
umask 177
# iirc this should be done by a sidecar container or something
backupfile=${backupdir}/db-${_date}
docker compose exec postgres su postgres -c '/usr/local/bin/pg_dump --dbname=postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@127.0.0.1:5432/${netbox} --format c --exclude-table-data extras_cachedvalue --exclude-table-data extras_objectchange' > ${backupfile}
# minimal test
file ${backupfile} | grep -q "PostgreSQL custom database dump" || exit 1
gzip -f -1 ${backupfile}
# Data Backup
backupfile=${backupdir}/objects-${_date}.gz
docker compose exec netbox tar -cf - --exclude=".git" --exclude="__pycache__" /opt/netbox/netbox/media /opt/netbox/netbox/reports /opt/netbox/netbox/scripts \
| gzip -1 > ${backupfile}
# minimal test
tar -tzvf ${backupfile} opt/netbox/netbox/media/image-attachments/.gitignore | grep -q opt/netbox/netbox/media/image-attachments/.gitignore || exit 1
@FlorianHeigl
Copy link
Author

lasted a whole minute till i wanted to improve it.

@FlorianHeigl
Copy link
Author

FlorianHeigl commented Mar 9, 2025

i would normally remove the set -e and trap ERR to drop a message, just didn't need it now. YMMV
in any case, the way it is, if this errors out, you have a failed backup, no questions there. thus the validation steps.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment