Skip to main content

Interactive backup and restore CLI for PostgreSQL, MariaDB, and MSSQL.

Project description

fuelrod-backup

Interactive backup and restore CLI for PostgreSQL, MariaDB/MySQL, and Microsoft SQL Server.

Features

  • Supports postgres, mariadb, and mssql engines
  • Interactive backup and restore wizards
  • Non-interactive backup mode for automation
  • Docker and direct-host connection modes
  • Config bootstrap wizard (init) and connection check (test)
  • Backup retention cleanup (KEEP_DAYS)

Installation

pip install fuelrod-backup

Or with pipx:

pipx install fuelrod-backup

Quick Start

  1. Initialize config:
fuelrod-backup init
  1. Validate connection:
fuelrod-backup test
  1. Run backup:
fuelrod-backup backup
  1. Run restore:
fuelrod-backup restore

Documentation

CLI Commands

fuelrod-backup backup [OPTIONS]
fuelrod-backup restore [OPTIONS]
fuelrod-backup test [OPTIONS]
fuelrod-backup init [OPTIONS]

backup options

  • --no-interactive, -n skip prompts and back up all databases
  • --compress / --no-compress override compression
  • --keep-days, -k override retention days (0 keeps forever)
  • --db, -d repeatable database selector
  • --docker / --no-docker override USE_DOCKER
  • --db-type, -t one of postgres | mariadb | mssql
  • --config, -c explicit config file path

restore and test options

  • --docker / --no-docker
  • --db-type, -t
  • --config, -c

init options

  • --output, -o output path for generated config (default .backup)

Config

Config is loaded in this order:

  1. defaults in code
  2. config file (--config if passed, otherwise auto-discovered)
  3. environment variables (highest priority)

Auto-discovery order

For each directory below, files are checked in this order:

  1. .backup
  2. .env
  3. .env-backup

Directories searched:

  1. current working directory
  2. project directory
  3. parent repo directory

Main keys

  • DB_TYPE=postgres|mariadb|mssql
  • DB_USERNAME, DB_PASSWORD, DB_HOST, DB_PORT
  • USE_DOCKER=true|false
  • SERVICE=<container-name>
  • BASE_DIR=<backup-root>
  • COMPRESS_FILE=true|false
  • KEEP_DAYS=<int>
  • CONNECTION_TIMEOUT=<seconds>

PostgreSQL-specific:

  • PG_DUMP_CMD
  • PG_RESTORE_CMD

MariaDB-specific:

  • MYSQL_DUMP_CMD
  • MYSQL_CMD

MSSQL-specific:

  • MSSQL_BACKUP_DIR

Notes

  • Effective backup output directory is <BASE_DIR>/<DB_TYPE>/....
  • PostgreSQL backups use custom format .dump (optional .gz).
  • MariaDB backups use .sql (optional .gz or .zip input supported on restore).
  • MSSQL backups use .bak.

License

GNU General Public License v3.0 or later. See LICENSE.

Breaking Change

Connection variables are now engine-agnostic only:

  • DB_USERNAME
  • DB_PASSWORD
  • DB_HOST
  • DB_PORT

Legacy connection keys (PG_USERNAME, PG_PASSWORD, PG_HOST, PG_PORT) are no longer loaded.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fuelrod_backup-3.0.0.tar.gz (76.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fuelrod_backup-3.0.0-py3-none-any.whl (93.0 kB view details)

Uploaded Python 3

File details

Details for the file fuelrod_backup-3.0.0.tar.gz.

File metadata

  • Download URL: fuelrod_backup-3.0.0.tar.gz
  • Upload date:
  • Size: 76.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.0 CPython/3.14.4 Linux/6.17.0-1010-azure

File hashes

Hashes for fuelrod_backup-3.0.0.tar.gz
Algorithm Hash digest
SHA256 b18f4aaad70fc89d0c69f81bad8be99eee0d2b108cfd20c573c67d8427d17d61
MD5 c0362bc27d878babf1914a4fe915555e
BLAKE2b-256 2252373fb40ccae8170aa4cff9d31548ff47eeb52b4bea948102ff166d0f10c7

See more details on using hashes here.

File details

Details for the file fuelrod_backup-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: fuelrod_backup-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 93.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.0 CPython/3.14.4 Linux/6.17.0-1010-azure

File hashes

Hashes for fuelrod_backup-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b807d483e89fe6815a77da07d17ceb93659f95f31ed2cc7870f455d766efd081
MD5 4b662dd80684d0551f93f872549d7fd1
BLAKE2b-256 1f74bcd8b9823d970395cb27cb033acfc4070b29c833b16fb7d59016d7046958

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page