mirror of
https://gitea.0xace.cc/ansible-galaxy/postgresql.git
synced 2025-01-18 12:02:25 +00:00
add restore from backup support
This commit is contained in:
parent
a2cfbde7e3
commit
98b48a3566
19
tasks/RedHat/data_dir.yaml
Normal file
19
tasks/RedHat/data_dir.yaml
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
- name: Create data directory
|
||||||
|
file:
|
||||||
|
path: "{{ postgresql_data_dir }}"
|
||||||
|
owner: "postgres"
|
||||||
|
group: "postgres"
|
||||||
|
state: directory
|
||||||
|
|
||||||
|
- name: Create override directory for systemd unit
|
||||||
|
file:
|
||||||
|
path: "{{ postgresql_system_override_dir }}"
|
||||||
|
state: directory
|
||||||
|
|
||||||
|
- name: Create override for data directory
|
||||||
|
copy:
|
||||||
|
dest: "{{ postgresql_system_override_dir }}/override.conf"
|
||||||
|
content: |
|
||||||
|
[Service]
|
||||||
|
Environment=PGDATA={{ postgresql_data_dir }}
|
||||||
|
notify: Restart PostgreSQL
|
88
tasks/restore.yaml
Normal file
88
tasks/restore.yaml
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
- name: Restore database
|
||||||
|
when: postgresql_wal_g_force_delete_and_restore
|
||||||
|
block:
|
||||||
|
- name: Stop PostgreSQL
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
name: "{{ postgresql_unit_name }}"
|
||||||
|
state: stopped
|
||||||
|
masked: no
|
||||||
|
|
||||||
|
- name: Force purge database directory
|
||||||
|
file:
|
||||||
|
path: "{{ postgresql_data_dir }}"
|
||||||
|
state: absent
|
||||||
|
|
||||||
|
- name: Recreate database directory
|
||||||
|
file:
|
||||||
|
path: "{{ postgresql_data_dir }}"
|
||||||
|
state: directory
|
||||||
|
become_user: postgres
|
||||||
|
|
||||||
|
- name: Check if d folder is empty before proceeding
|
||||||
|
find:
|
||||||
|
paths: "{{ postgresql_data_dir }}"
|
||||||
|
register: postgresql_files_found
|
||||||
|
|
||||||
|
- name: Restore database
|
||||||
|
when:
|
||||||
|
- postgresql_files_found.matched == 0
|
||||||
|
block:
|
||||||
|
- name: Restore database dir from backup
|
||||||
|
shell: "{{ postgresql_wal_g_binary_name ~ ' --config ' ~ postgresql_base_dir ~ '/' ~ postgresql_wal_g_restore_config_name ~ ' backup-fetch ' ~ postgresql_data_dir ~ ' ' ~ postgresql_wal_g_postgresql_pitr }}"
|
||||||
|
become_user: postgres
|
||||||
|
|
||||||
|
- name: Include PostgreSQL configuration
|
||||||
|
vars:
|
||||||
|
postgresql_restore_command: "{{ postgresql_wal_g_binary_name ~ ' --config ' ~ postgresql_base_dir ~ '/' ~ postgresql_wal_g_restore_config_name ~ ' wal-fetch %f %p' }}"
|
||||||
|
include_tasks: config.yaml
|
||||||
|
|
||||||
|
- name: Create recovery.signal file
|
||||||
|
file:
|
||||||
|
name: "{{ postgresql_data_dir }}/recovery.signal"
|
||||||
|
state: touch
|
||||||
|
become_user: postgres
|
||||||
|
|
||||||
|
- name: Create standby.signal file
|
||||||
|
file:
|
||||||
|
name: "{{ postgresql_data_dir }}/standby.signal"
|
||||||
|
state: touch
|
||||||
|
become_user: postgres
|
||||||
|
|
||||||
|
- name: Start PostgreSQL for recovery
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
name: "{{ postgresql_unit_name }}"
|
||||||
|
state: started
|
||||||
|
masked: no
|
||||||
|
register: postgresql_start_for_recovery
|
||||||
|
|
||||||
|
- name: Ping PostgreSQL server
|
||||||
|
vars:
|
||||||
|
ansible_python_interpreter: '/usr/bin/env python3'
|
||||||
|
community.postgresql.postgresql_ping:
|
||||||
|
db: "{{ postgresql_superuser_db }}"
|
||||||
|
login_user: "{{ postgresql_superuser_username }}"
|
||||||
|
login_password: "{{ postgresql_superuser_password }}"
|
||||||
|
register: postgresql_ping
|
||||||
|
until: postgresql_ping.is_available
|
||||||
|
retries: 60
|
||||||
|
delay: 20
|
||||||
|
|
||||||
|
- name: debug
|
||||||
|
debug:
|
||||||
|
msg: "{{ postgresql_ping }}"
|
||||||
|
|
||||||
|
- name: Stop PostgreSQL
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
name: "{{ postgresql_unit_name }}"
|
||||||
|
state: stopped
|
||||||
|
masked: no
|
||||||
|
register: postgresql_stop
|
||||||
|
|
||||||
|
- name: Create promote trigger file
|
||||||
|
file:
|
||||||
|
name: "{{ postgresql_promote_trigger_file }}"
|
||||||
|
state: touch
|
||||||
|
become_user: postgres
|
Loading…
Reference in New Issue
Block a user