Skip to main content

edwh plugin for quick database snapshot creation and recovery

Project description

EDWH Development Database (devdb) Plugin

Overview

The EDWH Development Database Plugin provides a comprehensive set of tools for managing snapshots of the development database. This plugin allows developers to create, push, pop, recover, and list database snapshots efficiently.

Features

  • Snapshot Management: Create and manage snapshots of the development database.
  • Selective Exclusion: Optionally exclude specific tables during snapshot creation.
  • Remote Operations: Push and pop snapshots to/from a remote server.
  • Database Recovery: Recover the database from previously created snapshots.
  • Environment Setup: Easy setup of environment variables for PostgreSQL connections.

Requirements

  • Python 3.12+
  • Docker Compose
  • PostgreSQL
  • EDWH environment variables configured (usually via edwh setup)

Installation

Development Installation

To install the plugin in development mode, run:

uv pip install -e .[dev]

Production Installation

For production use, you can install the plugin using:

uvenv install edwh[devdb]

Alternatively, you can add the plugin directly with:

edwh plugin.add devdb

Usage

Environment Variables

Ensure the following environment variables are set:

  • POSTGRES_USERNAME: Username for PostgreSQL (default: postgres)
  • POSTGRES_PASSWORD: Password for PostgreSQL (default: password)
  • PGPOOL_PORT: Port for pgpool (default: 5432)
  • POSTGRES_DATABASE: Name of the PostgreSQL database (default: backend)

Then you can run edwh setup and the other required variables can be infered.

Commands

Create a Snapshot

To create a snapshot of the development database:

ew devdb.snapshot

You can exclude specific tables using optional parameters:

ew devdb.snapshot --without_api_activity False --without_applog False

List Snapshots

To list all snapshots in reverse chronological order:

ew devdb.list

Rename a Snapshot

To rename the most recent snapshot:

ew devdb.rename <new_name>

Push a Snapshot

To push the local snapshot to a remote server:

ew devdb.push

Pop a Snapshot

To download and prepare a snapshot from a given URL:

ew devdb.pop <url>

Recover a Snapshot

To recover the database from a snapshot:

ew devdb.recover

This assumes an empty database. An easier alternative is:

Reset the Database

To reset your database to the latest state:

ew devdb.reset

Notes

  • Be cautious when using the reset command as it will clear your PostgreSQL database and remove all existing data.

Repository

The source code is available at GitHub.

License

This project is licensed under the MIT License.

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

edwh_devdb_plugin-0.7.1.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

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

edwh_devdb_plugin-0.7.1-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file edwh_devdb_plugin-0.7.1.tar.gz.

File metadata

  • Download URL: edwh_devdb_plugin-0.7.1.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.14 {"installer":{"name":"uv","version":"0.9.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Linux Mint","version":"22.2","id":"zara","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for edwh_devdb_plugin-0.7.1.tar.gz
Algorithm Hash digest
SHA256 d74259d6558f7ea84c15164df0e3202bd232196f8da265658da94c57662b1d9a
MD5 95f47734bccdd6c0ebad7beaad768a36
BLAKE2b-256 d05cb799159a61c1086d2a9cdde226e76bdd7cb116376d97f8eb7aab2a91bf07

See more details on using hashes here.

File details

Details for the file edwh_devdb_plugin-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: edwh_devdb_plugin-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.14 {"installer":{"name":"uv","version":"0.9.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Linux Mint","version":"22.2","id":"zara","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for edwh_devdb_plugin-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d10889ee43c9400024327d0ff273070ad28f3a710c5f93f9b1dd569cb7309df3
MD5 7e42a6ad7f1b2f24c0a9fd694dd7a6d9
BLAKE2b-256 2729036aa8695336cd45ba4adb6f9132fd6d14fd9e12046dfe6e7bf9f8fb5f30

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