Merge branch 'main' of https://git.mitscherlich.nl/matthias/backup
This commit is contained in:
@@ -2,18 +2,16 @@ pipeline {
|
||||
agent any
|
||||
parameters {
|
||||
booleanParam(name: 'backuplocally', defaultValue: params.backuplocally ?: false, description: 'If true local BORG backup will be created')
|
||||
booleanParam(name: 'backuptostackstorage', defaultValue: params.backuptostackstorage ?: false, description: 'If true backup data to TransIP Stack')
|
||||
booleanParam(name: 'backuptodavid', defaultValue: params.backuptodavid ?: false, description: 'If true rsync the BORG repository to David')
|
||||
booleanParam(name: 'backuptopi', defaultValue: params.backuptopi ?: false, description: 'If true rsync the BORG repository to our ExternalPI')
|
||||
booleanParam(name: 'backuptowinschoten', defaultValue: params.backuptowinschoten ?: false, description: 'If true rsync the BORG repository to our Winschoten backup system')
|
||||
}
|
||||
|
||||
stages {
|
||||
stage('Run Information') {
|
||||
steps {
|
||||
echo "Local BORG backup creation is ${params.backuplocally}"
|
||||
echo "Backup to TransIP Stack is ${params.backuptostackstorage}"
|
||||
echo "Backup to David is ${params.backuptodavid}"
|
||||
echo "Backup to External PI is ${params.backuptopi}"
|
||||
echo "Backup to Winschoten PI is ${params.backuptowinschoten}"
|
||||
}
|
||||
}
|
||||
stage('Run MariaDB') {
|
||||
@@ -45,30 +43,15 @@ pipeline {
|
||||
}
|
||||
}
|
||||
|
||||
stage('Run rclone') {
|
||||
agent {
|
||||
docker {
|
||||
image 'rclone/rclone'
|
||||
args "--volumes-from=jenkins -v /srv/dev-disk-by-uuid-27fc012e-a1fa-4c7c-9dad-82770888cd03/nextcloud_backup/database_dump/:/data/ --entrypoint=''"
|
||||
reuseNode true
|
||||
}
|
||||
}
|
||||
steps {
|
||||
script {
|
||||
if (params.backuptostackstorage) {
|
||||
sh "mkdir -p /config/rclone"
|
||||
sh "cp ${WORKSPACE}/config/rclone.conf /config/rclone/"
|
||||
sh "rclone copy -v /data/ stackstorage:/julien/nextcloud/database"
|
||||
} else {
|
||||
echo "Backup to TransIP Stack is skipped"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
stage('Run Rsync to David') {
|
||||
stage('Rsync Backup in Parallel') {
|
||||
failFast false
|
||||
parallel {
|
||||
stage ('Run Backup to David') {
|
||||
steps {
|
||||
script {
|
||||
if (params.backuptodavid) {
|
||||
sh "yes | cp -rf matthias@home.daf2000.nl:/media/disk/nextcloudbackup/database_dump/backup_yesterday.dmp matthias@home.daf2000.nl:/media/disk/nextcloudbackup/database_dump/backup_early.dmp 2>/dev/null || :"
|
||||
sh "yes | cp -rf matthias@home.daf2000.nl:/media/disk/nextcloudbackup/database_dump/backup_latest.dmp matthias@home.daf2000.nl:/media/disk/nextcloudbackup/database_dump/backup_yesterday.dmp 2>/dev/null || :"
|
||||
sh "rsync -v -a -e 'ssh -p 664' --delete --bwlimit=3000 --info=progress2 --exclude='.*' /srv/dev-disk-by-uuid-27fc012e-a1fa-4c7c-9dad-82770888cd03/nextcloud_backup/database_dump/ matthias@home.daf2000.nl:/media/disk/nextcloudbackup/database_dump/"
|
||||
} else {
|
||||
echo "Backup to David is skipped"
|
||||
@@ -76,6 +59,24 @@ pipeline {
|
||||
}
|
||||
}
|
||||
}
|
||||
stage ('Run Backup to Winschoten') {
|
||||
steps {
|
||||
script {
|
||||
if (params.backuptowinschoten) {
|
||||
withCredentials([sshUserPrivateKey(credentialsId: 'backupwinschoten', keyFileVariable: 'keyfile', passphraseVariable: 'passphrase', usernameVariable: 'user')]) {
|
||||
sh "cp ${keyfile} ${WORKSPACE}/keyfile"
|
||||
sh "rsync -v -a -e 'ssh -i /home/backupwinschoten/.ssh/id_rsa -p 9897' --delete --info=progress2 ${env.borglocation}/${directory} backupwinschoten@localhost:/storage/borgbackups/"
|
||||
}
|
||||
} else {
|
||||
echo "Backup to Winschoten is skipped"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
stage('Run Rsync to External PI') {
|
||||
steps {
|
||||
script {
|
||||
|
||||
Reference in New Issue
Block a user