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.1.0.tar.gz (49.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.1.0-py3-none-any.whl (59.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fuelrod_backup-2.1.0.tar.gz
  • Upload date:
  • Size: 49.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.3 CPython/3.13.12 Linux/6.17.0-1008-azure

File hashes

Hashes for fuelrod_backup-2.1.0.tar.gz
Algorithm Hash digest
SHA256 43e2a4b8089db9fa7a5599b59c5a6912bd2489ebcdb2d21b3dcfb9317b9e6049
MD5 56ab8703c58e5e68c8b59a76da4adf0c
BLAKE2b-256 579ead98af8c9bdfa3e91536acc2295ca671af08daa398dabab1868be6145c82

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fuelrod_backup-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 59.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.3 CPython/3.13.12 Linux/6.17.0-1008-azure

File hashes

Hashes for fuelrod_backup-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8a010c2fd962356a0ae99234518834d30e2fefb57c7834f4a07c9a6ab1b9cede
MD5 b1a8b66bd9304a0c46c05a79389f40bc
BLAKE2b-256 a8d834fbba41e1e3075c9b3d5f9ce022b38c326e81819aa8b013cca744ad850a

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