Add daily backup workflow for Neon database
This commit is contained in:
parent
c6fdd45d98
commit
9beb831da5
1 changed files with 38 additions and 0 deletions
38
.github/workflows/neon-backup.yml
vendored
Normal file
38
.github/workflows/neon-backup.yml
vendored
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
name: Daily Neon Database Backup
|
||||
|
||||
on:
|
||||
schedule:
|
||||
# Elke nacht om 02:00 UTC = 04:00 Nederlandse zomertijd / 03:00 wintertijd
|
||||
- cron: "0 2 * * *"
|
||||
|
||||
# Hiermee kun je handmatig testen via GitHub
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
backup:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Install PostgreSQL client
|
||||
run: |
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y postgresql-client
|
||||
|
||||
- name: Create backup
|
||||
env:
|
||||
DATABASE_URL: ${{ secrets.NEON_DATABASE_URL }}
|
||||
run: |
|
||||
mkdir -p backups
|
||||
DATE=$(date +"%Y-%m-%d_%H-%M-%S")
|
||||
pg_dump "$DATABASE_URL" \
|
||||
--format=custom \
|
||||
--no-owner \
|
||||
--no-privileges \
|
||||
--file="backups/neon-backup-$DATE.dump"
|
||||
|
||||
- name: Upload backup artifact
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: neon-database-backup
|
||||
path: backups/*.dump
|
||||
retention-days: 30
|
||||
Loading…
Add table
Add a link
Reference in a new issue