Compare commits

..

No commits in common. "d555f919beefd91f0ea7492544b7a645e6f17ce3" and "48b0335071f7a4dcb074a63f80e8ebfa6a6c00e8" have entirely different histories.

3 changed files with 41 additions and 55 deletions

View File

@ -1,12 +1,12 @@
## The playbook first runs the 'backup.yml' from each role
- name: create the /backup-dirs file # this also runs on main in case someone doesn't run the backup.yml
- name: create the /backup-dirs file
file:
path: "/backup-dirs"
state: "touch"
mode: "0400"
changed_when: "true" # we always want ti give roles a chance to register dirs
- name: Ensure file contains lines from array # this also runs on main in case someone doesn't run the backup.yml
- name: Ensure file contains lines from array
lineinfile:
path: /backup-dirs
line: "{{ item }}"

View File

@ -1,17 +1,5 @@
- name: create the /backup-dirs file # this also runs on main in case someone doesn't run the backup.yml
file:
path: "/backup-dirs"
state: "touch"
mode: "0400"
changed_when: "true" # we always want ti give roles a chance to register dirs
- name: Ensure file contains lines from array # this also runs on main in case someone doesn't run the backup.yml
lineinfile:
path: /backup-dirs
line: "{{ item }}"
create: yes
state: present
loop: "{{ extra_backup_paths }}"
- debug:
var: group_names
- name: make sure restic is installed
apt: state=latest pkg=restic

View File

@ -5,53 +5,51 @@ original_dir=$(pwd)
source ./vars.sh
cd "$original_dir"
(
./mount.sh &
RESTIC_PID=$!
./mount.sh &
RESTIC_PID=$!
MOUNT_DIR="/mnt/restic"
MOUNT_DIR="/mnt/restic"
# Wait until the directory exists
while [ ! -d "$MOUNT_DIR" ]; do
echo "Waiting for directory to be created..."
sleep 1
done
# Wait until the directory exists
while [ ! -d "$MOUNT_DIR" ]; do
echo "Waiting for directory to be created..."
sleep 1
done
# Wait until the directory is not empty
while [ ! "$(ls -A "$MOUNT_DIR")" ]; do
echo "Waiting for directory to have content..."
sleep 1
done
# Wait until the directory is not empty
while [ ! "$(ls -A "$MOUNT_DIR")" ]; do
echo "Waiting for directory to have content..."
sleep 1
done
# Space-separated list of absolute paths
BACKUP_DIR="$MOUNT_DIR/snapshots/latest"
# Space-separated list of absolute paths
BACKUP_DIR="$MOUNT_DIR/snapshots/latest"
# Iterate over each path in the array
while IFS= read -r ORIGINAL_PATH; do
# Skip empty paths
[[ -z "$ORIGINAL_PATH" ]] && continue
# Iterate over each path in the array
while IFS= read -r ORIGINAL_PATH; do
# Skip empty paths
[[ -z "$ORIGINAL_PATH" ]] && continue
# Construct the corresponding backup path
BACKUP_PATH="$BACKUP_DIR$ORIGINAL_PATH"
# Construct the corresponding backup path
BACKUP_PATH="$BACKUP_DIR$ORIGINAL_PATH"
# Check if the backup directory exists
if [[ ! -d "$BACKUP_PATH" ]]; then
echo "Backup directory not found: $BACKUP_PATH"
continue
fi
# Check if the backup directory exists
if [[ ! -d "$BACKUP_PATH" ]]; then
echo "Backup directory not found: $BACKUP_PATH"
continue
fi
# Ensure the original directory exists, create it if not
if [[ ! -d "$ORIGINAL_PATH" ]]; then
echo "Creating original directory: $ORIGINAL_PATH"
mkdir -p "$ORIGINAL_PATH"
fi
# Ensure the original directory exists, create it if not
if [[ ! -d "$ORIGINAL_PATH" ]]; then
echo "Creating original directory: $ORIGINAL_PATH"
mkdir -p "$ORIGINAL_PATH"
fi
# Use rsync to copy files, preserving permissions, ownership, and timestamps
rsync --archive --acls --xattrs --compress --verbose --human-readable --partial --progress "$BACKUP_PATH/" "$ORIGINAL_PATH/"
done </backup-dirs
# Use rsync to copy files, preserving permissions, ownership, and timestamps
rsync --archive --acls --xattrs --compress --verbose --human-readable --partial --progress "$BACKUP_PATH/" "$ORIGINAL_PATH/"
done </backup-dirs
kill -SIGINT $RESTIC_PID
umount /mnt/restic
kill -SIGINT $RESTIC_PID
umount /mnt/restic
echo "DONE"
) >"/var/log/backup-restore-$(date +%s).log"
echo "DONE"