backup revision
This commit is contained in:
8
backup/README.md
Normal file
8
backup/README.md
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# backups
|
||||||
|
|
||||||
|
## borgbackup cockpit (companion scripts)
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
borg list ${BORG_REPO}
|
||||||
|
borg list ${BORG_REPO}::gitea-data-2025-03-12_02:00:06
|
||||||
|
```
|
||||||
@@ -17,16 +17,16 @@ spec:
|
|||||||
command: ["sh", "-c"]
|
command: ["sh", "-c"]
|
||||||
args:
|
args:
|
||||||
- |
|
- |
|
||||||
echo "INFO: Starting export"
|
#echo "INFO: Starting export"
|
||||||
. /root/.gitea-inline-config/database
|
. /root/.gitea-inline-config/database
|
||||||
export PGPASSWORD=$PASSWD
|
export PGPASSWORD=$PASSWD
|
||||||
echo "INFO: Exporting database"
|
#echo "INFO: Exporting database"
|
||||||
pg_dump -h gitea-postgresql.git-limbosolutions-com.svc.cluster.local -U $USER -d $NAME > /data/postgresql-export/db_backup.sql
|
pg_dump -h gitea-postgresql.git-limbosolutions-com.svc.cluster.local -U $USER -d $NAME > /data/postgresql-export/db_backup.sql
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
echo "ERROR: Exporting database failed"
|
echo "ERROR: Exporting database failed"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo "INFO: Exporting database finished"
|
#echo "INFO: Exporting database finished"
|
||||||
|
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
|
|
||||||
@@ -64,7 +64,7 @@ spec:
|
|||||||
args:
|
args:
|
||||||
- |
|
- |
|
||||||
proxmox-backup-client backup gitea-data.pxar:/data/gitea-data postgresql-data.pxar:/data/postgresql-data postgresql-export.pxar:/data/postgresql-export --include-dev /data/postgresql-data --include-dev /data/postgresql-export --include-dev /data/gitea-data --backup-id "gitea-full" -ns git.limbosolutions.com
|
proxmox-backup-client backup gitea-data.pxar:/data/gitea-data postgresql-data.pxar:/data/postgresql-data postgresql-export.pxar:/data/postgresql-export --include-dev /data/postgresql-data --include-dev /data/postgresql-export --include-dev /data/gitea-data --backup-id "gitea-full" -ns git.limbosolutions.com
|
||||||
echo "INFO: git.limbosolutions.com finished"
|
echo "INFO: Backup git.limbosolutions.com finished"
|
||||||
|
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- name: gitea-shared-storage
|
- name: gitea-shared-storage
|
||||||
|
|||||||
@@ -18,16 +18,16 @@ spec:
|
|||||||
command: ["sh", "-c"]
|
command: ["sh", "-c"]
|
||||||
args:
|
args:
|
||||||
- |
|
- |
|
||||||
echo "INFO: Starting export"
|
#echo "INFO: Starting export"
|
||||||
. /root/.gitea-inline-config/database
|
. /root/.gitea-inline-config/database
|
||||||
export PGPASSWORD=$PASSWD
|
export PGPASSWORD=$PASSWD
|
||||||
echo "INFO: Exporting database"
|
#echo "INFO: Exporting database"
|
||||||
pg_dump -h gitea-postgresql.git-limbosolutions-com.svc.cluster.local -U $USER -d $NAME > /data/postgresql-export/db_backup.sql
|
pg_dump -h gitea-postgresql.git-limbosolutions-com.svc.cluster.local -U $USER -d $NAME > /data/postgresql-export/db_backup.sql
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
echo "ERROR: Exporting database failed"
|
echo "ERROR: Exporting database failed"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo "INFO: Exporting database finished"
|
#echo "INFO: Exporting database finished"
|
||||||
|
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
|
|
||||||
@@ -86,7 +86,7 @@ spec:
|
|||||||
|
|
||||||
${BORG_RSH} mf@backupsrv01.dev.lan \
|
${BORG_RSH} mf@backupsrv01.dev.lan \
|
||||||
"rclone sync ~/borg-repos/git.limbosolutions.com mf.onedrive:.backups/git.limbosolutions.com/borg" &&
|
"rclone sync ~/borg-repos/git.limbosolutions.com mf.onedrive:.backups/git.limbosolutions.com/borg" &&
|
||||||
echo "INFO: borg repo offsite sync finished"
|
echo "INFO: Backup git.limbosolutions.com (offsite) finished"
|
||||||
|
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- name: gitea-data
|
- name: gitea-data
|
||||||
|
|||||||
68
backup/borgbackup-cockpit-deploy.yaml
Normal file
68
backup/borgbackup-cockpit-deploy.yaml
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: borgbackup-cockpit
|
||||||
|
namespace: git-limbosolutions-com
|
||||||
|
labels:
|
||||||
|
app: borgbackup-cockpit
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: borgbackup-cockpit
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: borgbackup-cockpit
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: borg-client
|
||||||
|
image: git.limbosolutions.com/kb/borg-backup:latest
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
memory: "512Mi"
|
||||||
|
cpu: "500m"
|
||||||
|
requests:
|
||||||
|
memory: "256Mi"
|
||||||
|
cpu: "250m"
|
||||||
|
env:
|
||||||
|
- name: BORG_REPO
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: gitea-backup-secret
|
||||||
|
key: BORG_REPO
|
||||||
|
|
||||||
|
- name: BORG_PASSPHRASE
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: gitea-backup-secret
|
||||||
|
key: BORG_PASSPHRASE
|
||||||
|
|
||||||
|
- name: BORG_RSH
|
||||||
|
value: ssh -o StrictHostKeyChecking=no
|
||||||
|
|
||||||
|
- name: BORG_KEY_FILE
|
||||||
|
value: /root/.borg/key
|
||||||
|
|
||||||
|
command: ["sh", "-c"]
|
||||||
|
args:
|
||||||
|
- |
|
||||||
|
while true; do
|
||||||
|
sleep 1s
|
||||||
|
done
|
||||||
|
|
||||||
|
volumeMounts:
|
||||||
|
|
||||||
|
- name: gitea-backup-secret
|
||||||
|
mountPath: /root/.borg/key
|
||||||
|
subPath: BORG_KEY_FILE
|
||||||
|
|
||||||
|
- name: gitea-backup-secret
|
||||||
|
mountPath: /root/.ssh/id_rsa
|
||||||
|
subPath: SSH_ID_RSA
|
||||||
|
volumes:
|
||||||
|
- name: gitea-backup-secret
|
||||||
|
secret:
|
||||||
|
secretName: gitea-backup-secret
|
||||||
|
defaultMode: 0600
|
||||||
|
|
||||||
@@ -2,7 +2,10 @@
|
|||||||
|
|
||||||
# set source env variables
|
# set source env variables
|
||||||
. ./.env
|
. ./.env
|
||||||
|
|
||||||
|
# set variables in env file as export
|
||||||
export $(cut -d= -f1 ./.env)
|
export $(cut -d= -f1 ./.env)
|
||||||
|
|
||||||
|
|
||||||
envsubst < gitea-backup-secret.yaml | kubectl apply -f -
|
envsubst < gitea-backup-secret.yaml | kubectl apply -f -
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,8 @@ kind: Secret
|
|||||||
metadata:
|
metadata:
|
||||||
name: gitea-backup-secret
|
name: gitea-backup-secret
|
||||||
namespace: git-limbosolutions-com
|
namespace: git-limbosolutions-com
|
||||||
data:
|
type: Opaque
|
||||||
|
stringData:
|
||||||
PBS_REPOSITORY: ${PBS_REPOSITORY}
|
PBS_REPOSITORY: ${PBS_REPOSITORY}
|
||||||
PBS_PASSWORD: ${PBS_PASSWORD}
|
PBS_PASSWORD: ${PBS_PASSWORD}
|
||||||
PBS_FINGERPRINT: ${PBS_FINGERPRINT}
|
PBS_FINGERPRINT: ${PBS_FINGERPRINT}
|
||||||
|
|||||||
Reference in New Issue
Block a user