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-2.0.0.tar.gz (48.2 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-2.0.0-py3-none-any.whl (60.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fuelrod_backup-2.0.0.tar.gz
  • Upload date:
  • Size: 48.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.13.7 Windows/11

File hashes

Hashes for fuelrod_backup-2.0.0.tar.gz
Algorithm Hash digest
SHA256 6f09e7087032d5381917e26d089993354fa888662ac243e88424c9c0b12f6ba3
MD5 9daf92a70ce477050b0a486b09641476
BLAKE2b-256 a4988a121b3d0909ce4ae4fa9337620a140c7e56081bb07fd4a1a49423bee327

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fuelrod_backup-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 60.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.13.7 Windows/11

File hashes

Hashes for fuelrod_backup-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 97bb174e70692d2a8faa8d5d0e6ddbdfd5be429027b48b2a6411892d9b3a42eb
MD5 45fba9fedad62d4a460db43a438be9df
BLAKE2b-256 697b319b6faf49eeed378396599bce537c69d12e57e37f9c9de215e059e6acc4

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