From f3e6ce5eff33ed74ebb18150f3ecff962ffadf39 Mon Sep 17 00:00:00 2001 From: nihaldivyam Date: Wed, 17 Jul 2024 18:33:37 +0530 Subject: [PATCH] add pg_dumpall support to logical backup script --- .github/workflows/postgres-logical-backup.yml | 46 +++++++++++++++++++ .../Dockerfile | 1 + .../dump.sh | 6 +-- 3 files changed, 50 insertions(+), 3 deletions(-) create mode 100644 .github/workflows/postgres-logical-backup.yml rename {logical-backup => postgres-logical-backup}/Dockerfile (99%) rename {logical-backup => postgres-logical-backup}/dump.sh (97%) diff --git a/.github/workflows/postgres-logical-backup.yml b/.github/workflows/postgres-logical-backup.yml new file mode 100644 index 00000000..7b7bc177 --- /dev/null +++ b/.github/workflows/postgres-logical-backup.yml @@ -0,0 +1,46 @@ +name: Build Logical backup + +on: + push: + branches: [ "*" ] + paths: 'postgres-logical-backup/**' + tags: [ "v*" ] + +jobs: + build-and-push: + runs-on: ubuntu-latest + + steps: + - name: Checkout code + uses: actions/checkout@v2 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v1 + + - name: Generate container metadata + id: meta + uses: docker/metadata-action@v3 + with: + images: ghcr.io/obmondo/postgres-logical-backup + tags: | + type=ref,event=branch,enable=${{ !endsWith(github.ref, github.event.repository.default_branch) }} + type=raw,value=latest,enable=${{ endsWith(github.ref, github.event.repository.default_branch) }} + type=ref,event=tag + flavor: | + latest=false + - name: Login to GitHub Container Registry + uses: docker/login-action@v1 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Build & push container image + id: docker_build + uses: docker/build-push-action@v2 + with: + file: "./postgres-logical-backup/Dockerfile" + context: . + labels: ${{ steps.meta.outputs.labels }} + push: true + tags: ${{ steps.meta.outputs.tags }} \ No newline at end of file diff --git a/logical-backup/Dockerfile b/postgres-logical-backup/Dockerfile similarity index 99% rename from logical-backup/Dockerfile rename to postgres-logical-backup/Dockerfile index 7a40c939..59aa9648 100644 --- a/logical-backup/Dockerfile +++ b/postgres-logical-backup/Dockerfile @@ -39,4 +39,5 @@ COPY ./* ./ ENV PG_DIR=/usr/lib/postgresql + ENTRYPOINT ["/dump.sh"] diff --git a/logical-backup/dump.sh b/postgres-logical-backup/dump.sh similarity index 97% rename from logical-backup/dump.sh rename to postgres-logical-backup/dump.sh index f9de352c..bda482a6 100755 --- a/logical-backup/dump.sh +++ b/postgres-logical-backup/dump.sh @@ -21,7 +21,7 @@ function estimate_size { function dump { echo "Taking dump of ${PGDATABASE} from ${PGHOST}" # settings are taken from the environment - "$PG_BIN"/pg_dump + "$PG_BIN"/pg_dumpall --exclude-database='postgres' } function compress { @@ -42,7 +42,7 @@ function aws_delete_objects { [[ ! -z "${LOGICAL_BACKUP_S3_ENDPOINT}" ]] && args+=("--endpoint-url=${LOGICAL_BACKUP_S3_ENDPOINT}") [[ ! -z "${LOGICAL_BACKUP_S3_REGION}" ]] && args+=("--region=${LOGICAL_BACKUP_S3_REGION}") - aws s3api delete-objects "${args[@]}" --delete Objects=["$(printf {Key=%q}, "$@")"],Quiet=true + aws s3api delete-objects "${args[@]}" --delete Objects=["$(printf \{Key=%q\}, "$@")"],Quiet=true } export -f aws_delete_objects @@ -129,4 +129,4 @@ else [[ ${PIPESTATUS[0]} != 0 || ${PIPESTATUS[1]} != 0 || ${PIPESTATUS[2]} != 0 ]] && (( ERRORCOUNT += 1 )) set +x exit $ERRORCOUNT -fi +fi \ No newline at end of file