mirror of
https://gitlab.sectorq.eu/jaydee/omv_backup.git
synced 2025-07-01 15:48:33 +02:00
Compare commits
72 Commits
6bd7d5dde6
...
main
Author | SHA1 | Date | |
---|---|---|---|
1ecedd7c00 | |||
87c671d23b | |||
97297f0c4e | |||
58e2596d3d | |||
ff736e20f1 | |||
94f5a08920 | |||
3f7a77b7b0 | |||
687ffc828d | |||
f17f1ca372 | |||
d5b114e771 | |||
edb3091b2a | |||
10edb2b533 | |||
3bffbd872d | |||
af5d64200c | |||
95dd8fb52b | |||
45476954cc | |||
386e3ec75c | |||
854f0c828a | |||
06c776ee90 | |||
71d661dfb5 | |||
ca518405ff | |||
a1b4aff656 | |||
b40a7f795e | |||
50d9f18969 | |||
baa26b3a09 | |||
eff8120428 | |||
25151a5776 | |||
82b9f93e13 | |||
6fa3c016b2 | |||
23d32537c7 | |||
607f58ae0a | |||
dce4ccb711 | |||
b66a4598de | |||
3d2d8e5c3d | |||
b12359c373 | |||
cc698871f6 | |||
66867ae717 | |||
9554f194ac | |||
4ea82d55a8 | |||
d855defac0 | |||
a90c1d5589 | |||
5cae7332d5 | |||
e17d538c2b | |||
f9266b0bc9 | |||
7909eadad5 | |||
c5a71ef749 | |||
7a3da9ee7d | |||
ab5ba0e10d | |||
db3d4245d9 | |||
6b522f6cbc | |||
39d16f6f2c | |||
5ed0031208 | |||
fded5b677c | |||
67b73319e0 | |||
9daa539028 | |||
f22b99030b | |||
ac2d7d212e | |||
6a52d29803 | |||
fd99f4ef78 | |||
daeb2901f2 | |||
59f6d1669b | |||
ca9a2d0969 | |||
6ff4833e0b | |||
506e4cc7df | |||
ccf4d16c55 | |||
6acf13de4e | |||
e9b1c18bb7 | |||
6f70dbc83c | |||
2951d204a6 | |||
15e1275c5a | |||
c636e1f2e5 | |||
97ff1a3197 |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
.gitlab-ci.yml
|
@ -18,11 +18,13 @@
|
||||
|
||||
stages: # List of stages for jobs, and their order of execution
|
||||
- build
|
||||
|
||||
|
||||
|
||||
build-job: # This job runs in the build stage, which runs first.
|
||||
stage: build
|
||||
script:
|
||||
- echo "Compiling the code..."
|
||||
- echo "Compile complete."
|
||||
- curl -X POST https://kestra.sectorq.eu/api/v1/executions/webhook/jaydee/ansible-all/f851511c32ca9450 -d '{"tag":["setup","common"],"target":["m-server.home.lan"]}' -H 'Content-Type\: application/json'
|
||||
|
||||
- column=":"
|
||||
- echo "${flow_id}"
|
||||
- curl -X POST https://kestra.sectorq.eu/api/v1/executions/webhook/jaydee/ansible-all/${flow_id} -d '{"tag":["setup","omv_backup"],"target":["servers"]}' -H "Content-Type${column} application/json"
|
||||
rules:
|
||||
- if: '$CI_COMMIT_MESSAGE =~ /build/'
|
||||
|
@ -1,18 +1,52 @@
|
||||
import subprocess
|
||||
import requests
|
||||
import datetime
|
||||
import os
|
||||
import shutil
|
||||
now = datetime.datetime.now()
|
||||
PASSWORD = "l4c1j4yd33Du5lo"
|
||||
DATETIME = now.strftime("%Y%m%d%H%M%S")
|
||||
os.chdir("/share/docker_data/__backups/")
|
||||
print("Backup gitlab")
|
||||
cmnd = 'docker exec -t gitlab gitlab-backup create SKIP=artifacts,repositories,registry,uploads,builds,pages,lfs,packages,terraform_state'
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
allfiles = os.listdir("/share/docker_data/gitlab/data/backups/")
|
||||
for f in allfiles:
|
||||
shutil.move(f"/share/docker_data/gitlab/data/backups/{f}", "/share/docker_data/__backups/")
|
||||
|
||||
|
||||
print("Backup nextcloud")
|
||||
cmnd = 'docker exec --user www-data nextcloud-app-1 php occ maintenance:mode --on'
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = f"docker exec nextcloud-db-1 sh -c 'exec mysqldump --single-transaction -h localhost -u nextcloud -pl4c1j4yd33Du5lo nextcloud' > /share/docker_data/__backups/nextcloudDB_{DATETIME}.sql"
|
||||
cmnd = f"docker exec nextcloud-db-1 sh -c 'exec mysqldump --single-transaction -h localhost -u nextcloud -p{PASSWORD} nextcloud' > /share/docker_data/__backups/nextcloudDB_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = "docker exec --user www-data nextcloud-app-1 php occ maintenance:mode --off"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = f"zip -P {PASSWORD} nextcloudDB_{DATETIME}.sql.zip nextcloudDB_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
os.remove(f"nextcloudDB_{DATETIME}.sql")
|
||||
|
||||
print("Backup Bookstack")
|
||||
cmnd = f"docker exec bookstack-db-1 sh -c 'exec mysqldump --single-transaction -h localhost -u bookstack -p{PASSWORD} bookstackapp' > /share/docker_data/__backups/bookstack_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = f"zip -P {PASSWORD} bookstack_{DATETIME}.sql.zip bookstack_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
os.remove(f"bookstack_{DATETIME}.sql")
|
||||
|
||||
print("Backup Kestra")
|
||||
cmnd = f"docker exec kestra-postgres-1 sh -c 'pg_dump -h localhost -p 5432 -U kestra -d kestra' > /share/docker_data/__backups/kestra_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = f"zip -P {PASSWORD} kestra_{DATETIME}.sql.zip kestra_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
os.remove(f"kestra_{DATETIME}.sql")
|
||||
|
||||
print("Backup Authentik")
|
||||
cmnd = f"docker exec authentik-postgresql-1 sh -c 'pg_dump -h localhost -p 5432 -U authentik -d authentik' > /share/docker_data/__backups/authentik_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
cmnd = f"zip -P {PASSWORD} authentik_{DATETIME}.sql.zip authentik_{DATETIME}.sql"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
os.remove(f"authentik_{DATETIME}.sql")
|
||||
|
||||
|
||||
print("Backup portainer")
|
||||
headers = {
|
||||
@ -21,7 +55,7 @@ headers = {
|
||||
}
|
||||
|
||||
json_data = {
|
||||
'password': 'l4c1j4yd33Du5lo',
|
||||
'password': PASSWORD,
|
||||
}
|
||||
|
||||
response = requests.post('https://portainer.sectorq.eu/api/backup', headers=headers, json=json_data, verify=True)
|
||||
@ -32,4 +66,8 @@ response = requests.post('https://portainer.sectorq.eu/api/backup', headers=head
|
||||
#response = requests.post('https://portainer.sectorq.eu/api/backup', headers=headers, data=data, verify=False)
|
||||
|
||||
with open(f'/share/docker_data/__backups/portainer_snapshot_{DATETIME}.tar.gz', 'wb') as f:
|
||||
f.write(response.content)
|
||||
f.write(response.content)
|
||||
os.chdir("/share/docker_data/__backups/")
|
||||
print("Remove Old Files")
|
||||
cmnd = f" find ./ -maxdepth 1 -type f -mtime +15 -exec rm -f {{}} \\;"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
@ -20,7 +20,7 @@ import numpy as np
|
||||
|
||||
file_path = os.path.realpath(__file__)
|
||||
dir_path = os.path.dirname(file_path)
|
||||
VERSION="1.0.4"
|
||||
VERSION="1.0.7"
|
||||
# print(file_path)
|
||||
# print(dir_path)
|
||||
os.chdir(dir_path)
|
||||
@ -217,7 +217,6 @@ if _STOP:
|
||||
continue
|
||||
cmnd = f"docker stop {c.split()[-1]}"
|
||||
status, running_containers = subprocess.getstatusoutput(cmnd)
|
||||
|
||||
if _RESTORE:
|
||||
logging.info("Starting Restore")
|
||||
print("Starting Restore")
|
||||
@ -226,7 +225,7 @@ if _RESTORE:
|
||||
if _APP == "all":
|
||||
_DATE = "latest"
|
||||
if host == "rpi5.home.lan" or host == "rpi5":
|
||||
_APP = ["nginx","ha","gitea","gitlab","mailu","bitwarden","esphome","grafana","ingluxdb","kestra","matter-server","mosquitto","octoprint","octoprint2","pihole","unify_block","webhub","homepage","watchtower"]
|
||||
_APP = ["__backups", "nginx","ha","gitea","gitlab","mailu","bitwarden","esphome","grafana","ingluxdb","kestra","matter-server","mosquitto","octoprint","octoprint2","pihole","unify_block","webhub","homepage","watchtower"]
|
||||
else:
|
||||
cmnd = "ssh root@amd.home.lan 'ls /mnt/raid/backup/m-server/docker_data/latest'"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
@ -254,11 +253,11 @@ if _RESTORE:
|
||||
if _DATE == "pick":
|
||||
cmnd = f"ssh root@amd.home.lan 'ls {BACKUP_DEVICE}/backup/m-server/docker_data'"
|
||||
status, output = subprocess.getstatusoutput(cmnd)
|
||||
#print(output)
|
||||
print(output)
|
||||
dates = output.splitlines()
|
||||
n = 1
|
||||
for i in dates:
|
||||
logging.info(f"{n} - {i}" )
|
||||
print(f"{n} - {i}" )
|
||||
n += 1
|
||||
|
||||
ans = input("Pick a backup to restore : ")
|
||||
|
Reference in New Issue
Block a user