mirror of
https://github.com/roles-ansible/ansible_role_restic/
synced 2025-01-11 01:40:17 +01:00
improve scheduling of backups via cron or timers
improves the handling and differentiation of cronjobs and systemd timers. Rename the ``restic_create_cron`` variable to``restic_create_schedule``. Now new: ``restic_schedule_type: "systemd"``. RESOLVE #22
This commit is contained in:
parent
2626f8a858
commit
e0f3f5c87c
7 changed files with 42 additions and 30 deletions
28
README.md
28
README.md
|
@ -1,4 +1,5 @@
|
|||
# Ansible Role: restic
|
||||
Ansible Role: restic
|
||||
=======================
|
||||
|
||||
> **Beta:** This role is in beta status.
|
||||
|
||||
|
@ -6,7 +7,8 @@
|
|||
[![license](https://raw.githubusercontent.com/roles-ansible/ansible_role_restic/main/.github/license.svg)](https://github.com/roles-ansible/ansible_role_restic/blob/main/LICENSE)
|
||||
[![Ansible Galaxy](https://raw.githubusercontent.com/roles-ansible/ansible_role_restic/main/.github/galaxy.svg)](https://galaxy.ansible.com/do1jlr/restic)
|
||||
|
||||
## Description
|
||||
Description
|
||||
-------------
|
||||
[Restic](https://github.com/restic/restic) is a versatile Go based backup
|
||||
solution which supports multiple backends, deduplication and incremental
|
||||
backups.
|
||||
|
@ -17,15 +19,15 @@ Aditionally, it will setup executable scripts to run a Backup manually.
|
|||
|
||||
> This Project borrowed heavily from the
|
||||
> [donat-b/ansible-restic](https://github.com/donat-b/ansible-restic) and
|
||||
> tje [https://github.com/arillso/ansible.restic](https://github.com/arillso/ansible.restic)
|
||||
> ansible role. We try to make this role more modern by using systemd timer,
|
||||
> the [https://github.com/arillso/ansible.restic](https://github.com/arillso/ansible.restic)
|
||||
> ansible role. We try to make this role more easy to anderstand and modern by using systemd timer,
|
||||
> /etc/crontab to define backup paths, more absolute paths and less options. (no S3 Storage, No Windows...)
|
||||
|
||||
### Backup Scripts
|
||||
This role will create a backup script and a file with credentials usable with the `source` command on linux for each backup in the `restic_script_dir`.
|
||||
These executable scripts can be used to manually trigger a backup action, but
|
||||
are also used for automated backups if you have set `restic_create_cron` to true.
|
||||
make sure to not change the files manually, as this can interfere with your
|
||||
are also used for automated backups if you have set `restic_create_schedule` variable to true.
|
||||
Make sure to not change the files manually, as this can interfere with your
|
||||
backups quite a bit.
|
||||
|
||||
on Linux, if you want to take a manual snapshot, you can run the backup like this:
|
||||
|
@ -69,9 +71,10 @@ ansible-galaxy install arillso.restic
|
|||
| `restic_install_path` | `'/usr/local/bin'` | Install location for the restic binary |
|
||||
| `restic_script_dir` | `'/opt/restic'` | Location of the generated backup scripts |
|
||||
| `restic_log_dir` | `'{{ restic_script_dir }}/log'` | Location of the logs of the backup scripts |
|
||||
| `restic_repos` | `{}` | A dictionary of repositories where snapshots are stored |
|
||||
| `restic_backups` | `{}` (or `[]`) | A list of dictionaries specifying the files and directories to be backed up |
|
||||
| `restic_create_cron` | `false` | Should a cronjob be created for each backup |
|
||||
| `restic_repos` | `{}` | A dictionary of repositories where snapshots are stored. *(More Info: [Repos](#Repos))* |
|
||||
| `restic_backups` | `{}` (or `[]`) | A list of dictionaries specifying the files and directories to be backed up *(More Infos: [Backups](#Backups))* |
|
||||
|`restic_create_schedule`| `false` | Should we schedule each backup. Either via cronjob or via systemd timer.|
|
||||
| `restic_schedule_type` | `systemd` | Here you can define if we create a ``cronjob`` or a ``systemd`` timer. If it fails to create a systemd timer, a cronjob will be created. |
|
||||
| `restic_dir_owner` | `'{{ansible_user}}'` | The owner of all created dirs |
|
||||
| `restic_dir_group` | `'{{ansible_user}}'` | The group of all created dirs |
|
||||
|
||||
|
@ -93,11 +96,6 @@ Available variables:
|
|||
| `location` | yes | The location of the Backend. Currently, [Local](https://restic.readthedocs.io/en/stable/030_preparing_a_new_repo.html#local), [SFTP](https://restic.readthedocs.io/en/stable/030_preparing_a_new_repo.html#sftp), [S3](https://restic.readthedocs.io/en/stable/030_preparing_a_new_repo.html#amazon-s3) and [B2](https://restic.readthedocs.io/en/stable/030_preparing_a_new_repo.html#backblaze-b2) are supported |
|
||||
| `password` | yes | The password used to secure this repository |
|
||||
| `init` | no | Describes if the repository should be initialized or not. Use `false` if you are backuping to an already existing repo. |
|
||||
| `aws_access_key` | no | The access key for the S3 backend |
|
||||
| `aws_secret_access_key` | no | The secret access key for the S3 backend |
|
||||
| `aws_default_region` | no | The desired region for the S3 backend |
|
||||
| `b2_account_id` | no | The account ID for Backblaze B2 backend |
|
||||
| `b2_account_key` | no | The account key for Backblaze B2 backend |
|
||||
|
||||
Example:
|
||||
```yaml
|
||||
|
@ -136,7 +134,7 @@ Available variables:
|
|||
| `keep_within` | no | If set, only keeps snapshots in this time period. |
|
||||
| `keep_tag` | no | If set, keep snapshots with this tags. Make sure to specify a list. |
|
||||
| `prune` | no (`false`) | If `true`, the `restic forget` command in the script has the [`--prune` option](https://restic.readthedocs.io/en/stable/060_forget.html#removing-backup-snapshots) appended. |
|
||||
| `scheduled` | no (`false`) | If `restic_create_cron` is set to `true`, this backup is scheduled and tries to create a systemd timer unit. If it fails, it is creating a cronjob. |
|
||||
| `scheduled` | no (`false`) | If `restic_create_schedule` is set to `true`, this backup is scheduled and tries to create a systemd timer unit. If it fails, it is creating a cronjob. |
|
||||
| `schedule_oncalendar` | ``'*-*-* 02:00:00'`` | The time for the systemd timer. Please notice the randomDelaySec option. By Default the backup is done every night at 2 am (+0-4h). But only if scheduled is true. |
|
||||
| `schedule_minute` | no (`*`) | Minute when the job is run. ( 0-59, *, */2, etc ) |
|
||||
| `schedule_hour` | no (`2`) | Hour when the job is run. ( 0-23, *, */2, etc ) |
|
||||
|
|
|
@ -8,7 +8,9 @@ restic_script_dir: '/opt/restic'
|
|||
restic_log_dir: '{{ restic_script_dir }}/log'
|
||||
restic_repos: {}
|
||||
restic_backups: []
|
||||
restic_create_cron: false
|
||||
restic_create_schedule: "{{ restic_create_cron }}"
|
||||
restic_schedule_type: "systemd"
|
||||
# restic_schedule_type: "cronjob"
|
||||
|
||||
restic_dir_owner: '{{ ansible_user | default(ansible_user_id) }}'
|
||||
restic_dir_group: '{{ ansible_user | default(ansible_user_id) }}'
|
||||
|
@ -19,3 +21,6 @@ restic_systemd_timer_default_OnCalendar: '*-*-* 02:00:00'
|
|||
|
||||
# perform simple version check for this role? (true is recomended)
|
||||
submodules_versioncheck: false
|
||||
|
||||
# outdated variables because of irritating names, but kept for compatibility
|
||||
restic_create_cron: false
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
daemon_reload: true
|
||||
with_items: '{{ restic_backups }}'
|
||||
when:
|
||||
- restic_create_cron
|
||||
- restic_create_schedule
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
- ansible_service_mgr == 'systemd'
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
- name: Converge
|
||||
hosts: all
|
||||
roles:
|
||||
- role: ansible_role_restic
|
||||
- {role: ansible_role_restic}
|
||||
pre_tasks:
|
||||
- name: install bzip2
|
||||
package:
|
||||
|
|
|
@ -25,8 +25,8 @@
|
|||
distribution_version: '{{ ansible_distribution_version }}'
|
||||
distribution_major_version: '{{ ansible_distribution_major_version }}'
|
||||
|
||||
- name: create restic systemd timer
|
||||
ansible.builtin.include_tasks: 'timer.yml'
|
||||
- name: schedule restic backup
|
||||
ansible.builtin.include_tasks: 'schedule.yml'
|
||||
loop_control:
|
||||
loop_var: loop_distribution
|
||||
vars:
|
||||
|
|
|
@ -13,7 +13,6 @@
|
|||
with_items: '{{ restic_backups }}'
|
||||
notify: systemctl restart restic.timer
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
|
||||
|
@ -28,7 +27,6 @@
|
|||
no_log: true
|
||||
with_items: '{{ restic_backups }}'
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
|
||||
|
@ -43,7 +41,6 @@
|
|||
no_log: true
|
||||
with_items: '{{ restic_backups }}'
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
|
||||
|
@ -56,7 +53,6 @@
|
|||
with_items: '{{ restic_backups }}'
|
||||
notify: systemctl restart restic.timer
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
|
||||
|
@ -70,7 +66,6 @@
|
|||
with_items: '{{ restic_backups }}'
|
||||
notify: systemctl restart restic.timer
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
|
||||
|
@ -89,16 +84,17 @@
|
|||
no_log: true
|
||||
with_items: '{{ restic_backups }}'
|
||||
when:
|
||||
- restic_create_cron
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
when: ansible_service_mgr == 'systemd'
|
||||
when:
|
||||
- ansible_service_mgr == 'systemd'
|
||||
- restic_schedule_type == "systemd"
|
||||
- restic_create_schedule | bool
|
||||
rescue:
|
||||
- name: set cronjob intead of systemd
|
||||
set_fact:
|
||||
restic_force_cron: true
|
||||
|
||||
|
||||
- name: install cronjob instead of systemd
|
||||
ansible.builtin.cron:
|
||||
name: "do1jlr.restic backup {{ item.name }}"
|
||||
|
@ -114,7 +110,20 @@
|
|||
no_log: true
|
||||
with_items: '{{ restic_backups }}'
|
||||
when:
|
||||
- restic_create_cron
|
||||
- restic_create_schedule
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
- ansible_service_mgr != 'systemd' or restic_force_cron | default(false)
|
||||
- restic_schedule_type == "cronjob" or restic_force_cron | default(false)
|
||||
|
||||
- name: make sure no unwanted systemd timer is available
|
||||
ansible.builtin.systemd:
|
||||
name: "restic-{{ item.name | replace(' ', '') | string }}.timer"
|
||||
state: stopped
|
||||
enabled: false
|
||||
when:
|
||||
- restic_create_schedule
|
||||
- item.name is defined
|
||||
- item.scheduled | default(false)
|
||||
- ansible_service_mgr != 'systemd' or restic_force_cron | default(false)
|
||||
- restic_schedule_type == "cronjob" or restic_force_cron | default(false)
|
|
@ -10,5 +10,5 @@ restic_os_variables:
|
|||
paths:
|
||||
- 'vars'
|
||||
|
||||
playbook_version_number: 12 # should be int
|
||||
playbook_version_number: 13 # should be int
|
||||
playbook_version_path: 'do1jlr.restic.version'
|
||||
|
|
Loading…
Reference in a new issue