Skip to content

Latest commit

 

History

History
61 lines (48 loc) · 3.57 KB

README.md

File metadata and controls

61 lines (48 loc) · 3.57 KB

pgsnap

With pgsnap, you can easily create a snapshot of a PostgreSQL database and transfer it to a S3-compatible storage, all while ensuring that old files are automatically deleted.

Features

  • 🗄 Creates a snapshot from a PostgreSQL database.
  • ☁ Sends the snapshot to a S3-compatible storage bucket (S3, Digital Ocean Spaces, MinIO, etc.)
  • 🧹 Retention Policy: Removes old snapshots from the bucket.

Configuration

The easiest way to run pgsnap is via our provided container image.

docker pull docker pull ghcr.io/openformation/pgsnap:latest

pgsnap gets configured via the following environment variables.

Name Description Required Default
DATABASE_NAME The name of the Yes
DATABASE_URL The PostgreSQL DSN Yes
S3_BUCKET_NAME The name of the storage bucket. Yes
S3_ACCESS_KEY The access key for accessing the storage bucket. Yes
S3_SECRET_KEY The secret key for accessing the storage bucket. Yes
S3_HOST The API host of the S3-compatible storage service. No s3.amazonaws.com
S3_REGION The region of the S3-compatible storage engine. No eu-central-1
SENTRY_DSN Sentry DSN. Required when you want to use Cron Monitoring. No
SENTRY_MONITOR_ID The Sentry Cron Monitoring ID. No
SENTRY_ORGANIZATION The name of your Sentry organization. No

Using as a Kubernetes CronJob

pgsnap can be easily run as a Kubernetes CronJob. The following example runs pgsnap every night at 2am (timezone: Europe/Berlin). The environment variables are stored in a Kubernetes Secret:

apiVersion: batch/v1
kind: CronJob
metadata:
  name: pgsnap
spec:
  schedule: 0 2 * * *
  timeZone: Europe/Berlin # Beta in Kubernetes 1.25
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: pgsnap
            image: ghcr.io/openformation/pgsnap:1.0.0
            envFrom:
            - secretRef:
                name: pgsnap-env-variables

License

Copyright (c) 2023 Open Formation GmbH

Licensed under the AGPL license.