Skip to content

Latest commit

 

History

History
250 lines (175 loc) · 5.69 KB

File metadata and controls

250 lines (175 loc) · 5.69 KB

setup_pgbackrestserver

This role is for setting up pgBackRest server. pgBackRest is a backup and recovery tool for Postgres.

Requirements

Following are the requirements of this role.

  1. Ansible
  2. edb_devops.edb_postgres -> setup_repo role for setting the repository on the systems.
  3. edb_devops.edb_postgres -> setup_pgbackrest role for setting up pgbackrest on all other cluster nodes.

Role Variables

pgbackrest_user

System user running pgBackRest commands. Default: pgbackrest

Example:

pgbackrest_user: 'pgbackrest'

pgbackrest_group

System group the pgbackrest user is part of. Default: pgbackrest

Example:

pgbackrest_group: 'pgbackrest'

pgbackrest_configuration_file

pgBackRest main configuration file path. Default: /etc/pgbackrest.conf

Example:

pgbackrest_configuration_file: '/etc/pgbackrest.conf'

pgbackrest_lock_path

Path of the pgBackRest lock directory. Default: /var/run/pgbackrest

Example:

pgbackrest_lock_path: '/var/run/pgbackrest'

pgbackrest_home

Path of the pgbackrest home directory. Backup files and archived WAL files are stored in this root directory. Default: /var/lib/pgbackrest

Example:

pgbackrest_home: '/var/lib/pgbackrest'

pgbackrest_log_file

pgBackRest logging file path. Default: /var/log/pgbackrest/pgbackrest.log

Example:

pgbackrest_log_file: '/var/log/pgbackrest/pgbackrest.log'

pgbackrest_log_level_console

Logging level for console logging. Could be off, error, warn, info, detail, debug or trace. Default: info

Example:

pgbackrest_log_level_console: 'info'

pgbackrest_log_level_file

Logging level for file logging. Could be off, error, warn, info, detail, debug or trace. Default: debug

Example:

pgbackrest_log_level_file: 'debug'

archive_repo_directory

Path of the pgBackRest archive repository. Backup files and archived WAL files are stored in this directory. Default: /var/lib/pgbackrest/backups

Example:

archive_repo_directory: '/var/lib/pgbackrest/backups'

repo_retention_full_type

Retention type for full backups. Determines if the value set in repo_retention_full represents a time period (days) or number of full backups to keep. Could be count or time. Default: count

Example:

repo_retention_full_type: "count"

repo_retention_full

Number of full backups to keep. Default: 2

Example:

repo_retention_full: 2

repo_cipher_type

Cipher to encrypt the repository. Could be none or aes-256-cbc. Default: aes-256-cbc

Example:

repo_cipher_type: 'aes-256-cbc'

backup_standby

Perform backups on a standby instead of the primary. Both primary and standby databases are required to perform a backup, although a majority of the files will be copied from the standby to reduce load on the primary. Default: n

Example:

backup_standby: "y"

process_max

Number of parallel processes used during backup and recovery. Setting too high may impact database performance. Default: 1

Example:

process_max: 1

delta

Restore or backup using checksums instead of timestamps. During a restore, the cluster data are expected to be present but empty. If they are not empty, the restore will fail. Setting delta:y will have pgBackRest automatically determine which files in database cluster directory need to be restored and which can be preserved. It will remove any unrecognized files to avoid divergent changes. Default: n

Example:

delta: "y"

primary_pgbr_config_file

File path of pgBackRest main configuration file on all other nodes running pgBackRest. Default: /etc/pgbackrest.conf

Example:

primary_pgbr_config_file: '/etc/pgbackrest.conf'

pg_instance_name

Name of the postgres instance running on primary node. Default: main

Example:

pg_instance_name: 'main'

Dependencies

This role requires the setup_pgbackrest role to be run on cluster nodes, and packages repositories should have been configured beforehand with the setup_repo role.

Example Playbook

Inventory file content

Content of the inventory.yml file:

---
all:
  children:
    pgbackrestserver:
      hosts:
        pgbackrest1:
          ansible_host: xxx.xxx.xxx.xxx
          private_ip: xxx.xxx.xxx.xxx

How to include the setup_pgbackrestserver role in your Playbook

Below is an example of how to include the setup_pgbackrestserver role:

---
- hosts: pgbackrestserver
  name: Deploy pgbackrest servers
  become: yes
  gather_facts: yes
  any_errors_fatal: true

  collections:
    - edb_devops.edb_postgres
  
  pre_tasks:
    - name: Initialize the user defined variables
      set_fact:
        pg_version: 14
        pg_type: "PG"
        repo_cipher_password: "password"
        repo_retention_full_type: "count"
        repo_retention_full: 2

  roles:
    - role: setup_repo
      when: "'setup_repo' in lookup('edb_devops.edb_postgres.supported_roles', wantlist=True)"
    - role: setup_pgbackrestserver
      when: "'setup_pgbackrestserver' in lookup('edb_devops.edb_postgres.supported_roles', wantlist=True)"
    - role: setup_pgbackrest
      when: "'setup_pgbackrest' in lookup('edb_devops.edb_postgres.supported_roles', wantlist=True)"

Defining and adding variables is done in the set_fact of the pre_tasks.

All the variables are available at:

License

BSD

Author information

Author: