infra/roles/backup/tasks/main.yml
jack fc6b1c0cec
Some checks failed
CI/CD / syntax-check (push) Successful in 39s
CI/CD / deploy (push) Has been cancelled
feat: Timeweb S3 offsite backup uploads
- Add vault_s3_access_key / vault_s3_secret_key to Ansible Vault
- Expose via s3_access_key / s3_secret_key in all/main.yml
- Add s3_endpoint + s3_bucket to backup role defaults
- Install awscli via apt in backup role tasks
- Extend backup.sh.j2: upload *.gz to S3 after local backup,
  prune S3 objects older than backup_retention_days

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-22 03:58:58 +07:00

30 lines
698 B
YAML

---
- name: Install awscli for S3 uploads
ansible.builtin.apt:
name: awscli
state: present
- name: Create backup directory
ansible.builtin.file:
path: "{{ backup_dir }}"
state: directory
owner: "{{ backup_user }}"
group: "{{ backup_user }}"
mode: "0750"
- name: Deploy backup script
ansible.builtin.template:
src: backup.sh.j2
dest: /usr/local/bin/backup-services
owner: root
group: root
mode: "0750"
- name: Schedule daily backup at 03:00
ansible.builtin.cron:
name: "Daily services backup"
minute: "0"
hour: "3"
job: "/usr/local/bin/backup-services >> /var/log/backup-services.log 2>&1"
user: root
state: present