Versionen im Vergleich

Schlüssel

  • Diese Zeile wurde hinzugefügt.
  • Diese Zeile wurde entfernt.
  • Formatierung wurde geändert.

...

UI Steps


UI Step

Installieren des postgres-clients z.B. per "apt-get install postgresql-client-11"


UI Step

Back-Up-Skript "/path/to/backup-script/backup_dbs.sh" anlegen, .pgpass anlegen, Pfade und DB-Namen ersetzen

Codeblock
languagebash
titleBackup-Script
collapsetrue
#!/bin/bash

DATE=`date +%d-%m-%y`
BACKUP_PATH=/path/to/backup-directory 
declare -a databases=(db1 db2 db3 etc)
A databases
databases[dbname]=dbport
databases[dbname2]=dbport
databases[dbname3]=dbport
databases[dbname4]=dbport
# Erstmal aufräumen alles was älter als eine Woche ist.
find $BACKUP_PATH/*.pgdump -mtime +7 -exec rm {} \;

# Dann können wir sichern
# das DB-Passwort ist in .pgpass im User-Home  gespeichert -> https://www.postgresql.org/docs/9.3/libpq-pgpass.html  
# Über alle Keys (DB-Name) des Arrays iterieren und den Value als Port eintragen
for database in "${!databases[@]}"
 do
  	pg_dump -h  hostip  -Fc -w -U postgres -p PORT${databases[$database]} -f $BACKUP_PATH/"$database"_$DATE.pgdump -d "$database"
done


UI Text Box
typenote

Die Skriptausführung erlauben. chmod u=rwx /path/to/backup-script/backup_dbs.sh



UI Step

Cron-Job anlegen, dazu crontab des Benutzers öffen, "crontab -e" (bei der ersten Ausführung wird nach dem Standardeditor gefragt)

Job-Anweisung eintragen (bedeutet 2 Uhr nachts)

Codeblock
languagebash
titlecrontab pscontent-user
collapsetrue
0 2 * * * sh /path/to/backup-script/backup_dbs.sh >/dev/null 2>&1



...