|
|
|
@ -49,12 +49,12 @@
|
|
|
|
- "stage_{{ stage }}"
|
|
|
|
- "stage_{{ stage }}"
|
|
|
|
- 'restore'
|
|
|
|
- 'restore'
|
|
|
|
changed_when: False
|
|
|
|
changed_when: False
|
|
|
|
- name: "Add 'storage' servers to hosts if necessary"
|
|
|
|
- name: "Add 'backup' servers to hosts if necessary"
|
|
|
|
add_host:
|
|
|
|
add_host:
|
|
|
|
name: "{{ stage }}-fgrz-01"
|
|
|
|
name: "{{ stage }}-backup-01"
|
|
|
|
groups:
|
|
|
|
groups:
|
|
|
|
- "stage_{{ stage }}"
|
|
|
|
- "stage_{{ stage }}"
|
|
|
|
- storage
|
|
|
|
- backup
|
|
|
|
changed_when: False
|
|
|
|
changed_when: False
|
|
|
|
|
|
|
|
|
|
|
|
#############################################################
|
|
|
|
#############################################################
|
|
|
|
@ -98,24 +98,61 @@
|
|
|
|
- role: restore_{{ database_engine }}
|
|
|
|
- role: restore_{{ database_engine }}
|
|
|
|
|
|
|
|
|
|
|
|
#############################################################
|
|
|
|
#############################################################
|
|
|
|
# Syncing backups from storage server to restore server
|
|
|
|
# add restore specific firewall rule
|
|
|
|
#############################################################
|
|
|
|
#############################################################
|
|
|
|
|
|
|
|
|
|
|
|
- hosts: "storage"
|
|
|
|
- hosts: "{{ stage }}-virtual-host-to-read-groups-vars"
|
|
|
|
|
|
|
|
serial: "{{ serial_number | default(1) }}"
|
|
|
|
|
|
|
|
gather_facts: false
|
|
|
|
|
|
|
|
connection: local
|
|
|
|
|
|
|
|
vars:
|
|
|
|
|
|
|
|
hcloud_firewall_objects_backup:
|
|
|
|
|
|
|
|
-
|
|
|
|
|
|
|
|
name: "{{ stage }}-restore-ssh-access"
|
|
|
|
|
|
|
|
state: present
|
|
|
|
|
|
|
|
rules:
|
|
|
|
|
|
|
|
-
|
|
|
|
|
|
|
|
direction: in
|
|
|
|
|
|
|
|
protocol: tcp
|
|
|
|
|
|
|
|
port: '22'
|
|
|
|
|
|
|
|
source_ips:
|
|
|
|
|
|
|
|
- "{{ lookup('community.general.dig', groups['backup'][0] + '.' + domain ) }}/32"
|
|
|
|
|
|
|
|
destination_ips: []
|
|
|
|
|
|
|
|
description: null
|
|
|
|
|
|
|
|
apply_to:
|
|
|
|
|
|
|
|
-
|
|
|
|
|
|
|
|
type: label_selector
|
|
|
|
|
|
|
|
label_selector:
|
|
|
|
|
|
|
|
selector: 'service=restore'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
- name: "Add hcloud firewall rule(s)"
|
|
|
|
|
|
|
|
include_role:
|
|
|
|
|
|
|
|
name: hcloud
|
|
|
|
|
|
|
|
tasks_from: configure-firewall2
|
|
|
|
|
|
|
|
loop: "{{ hcloud_firewall_objects_backup }}"
|
|
|
|
|
|
|
|
loop_control:
|
|
|
|
|
|
|
|
loop_var: firewall_object
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#############################################################
|
|
|
|
|
|
|
|
# Syncing backups from backup server to restore server
|
|
|
|
|
|
|
|
#############################################################
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- hosts: "backup"
|
|
|
|
serial: "{{ serial_number | default(5) }}"
|
|
|
|
serial: "{{ serial_number | default(5) }}"
|
|
|
|
gather_facts: false
|
|
|
|
gather_facts: false
|
|
|
|
vars:
|
|
|
|
vars:
|
|
|
|
storageserver_system_user: 'backuphamster'
|
|
|
|
backupserver_system_user: 'backuphamster'
|
|
|
|
ansible_ssh_host: "{{ stage_server_domain }}"
|
|
|
|
ansible_ssh_host: "{{ stage_server_domain }}"
|
|
|
|
tasks:
|
|
|
|
tasks:
|
|
|
|
# I could not get it up and running with <synchronize> module
|
|
|
|
# I could not get it up and running with <synchronize> module
|
|
|
|
# to sync data from remote server A to remote server B
|
|
|
|
# to sync data from remote server A to remote server B
|
|
|
|
- name: "Syncing remote backups"
|
|
|
|
- name: "Syncing remote backups"
|
|
|
|
become: yes
|
|
|
|
become: yes
|
|
|
|
become_user: '{{ storageserver_system_user }}'
|
|
|
|
become_user: '{{ backupserver_system_user }}'
|
|
|
|
vars:
|
|
|
|
vars:
|
|
|
|
database_server_ip: "{{ stage }}-restore-{{ database_engine }}-01.{{ domain }}"
|
|
|
|
database_server_ip: "{{ groups['restore'][0] }}.{{ domain }}"
|
|
|
|
shell: '/home/{{ storageserver_system_user }}/push_backups_to_restore_server.sh {{ database_server_ip }} {{ stage }} {{ database_engine }}'
|
|
|
|
shell: '/home/{{ backupserver_system_user }}/push_backups_to_restore_server.sh {{ database_server_ip }} {{ stage }} {{ database_engine }}'
|
|
|
|
|
|
|
|
|
|
|
|
#############################################################
|
|
|
|
#############################################################
|
|
|
|
# Restoring from backup
|
|
|
|
# Restoring from backup
|
|
|
|
|