Skip to content

Latest commit

 

History

History
146 lines (102 loc) · 3.07 KB

README.md

File metadata and controls

146 lines (102 loc) · 3.07 KB

tuning

The tuning role configures the system and Postgres instances for optimal performances. Most of the configuration values are calculated automatically from available resources found on the system.

Requirements

Following are the dependencies and requirement of this role.

  1. Ansible

Role Variables

When executing the role via ansible these are the required variables:

  • pg_version

Postgres Versions supported are: 10, 11, 12, 13 and 14

  • pg_type

Database Engine supported are: PG and EPAS

These and other variables can be assigned in the pre_tasks definition of the section: How to include the tuning role in your Playbook

The rest of the variables can be configured and are available in the:

pg_conf_override_tuning

Defines if the pg_postgres_conf_params should override the tuning values automaticaly calculated from gathered memory informations. Default: false

Example:

pg_conf_override_tuning: "true"
pg_postgres_conf_params:
- name: shared_buffers
  value: "128MB"

tuned_profile

This is the tuned profile name used for configuring the system. Default: edb

Example:

tuned_profile: "edb"

tuned_configuration_dir

tuned configuration directory path. Default: /etc/tuned

Example:

tuned_configuration_dir: "/etc/tuned"

ssd_disk

Let the role knows if the system uses SSD disk based storage. Default: no

Example:

ssd_disk: yes

Dependencies

This role does not have any dependencies, but a Postgres instance should have been deployed beforehand with the init_dbserver or setup_replication roles.

Example Playbook

Inventory file content

Content of the inventory.yml file:

---
all:
  children:
    primary:
      hosts:
        primary1:
          ansible_host: xxx.xxx.xxx.xxx
          private_ip: xxx.xxx.xxx.xxx
    standby:
      hosts:
        standby1:
          ansible_host: xxx.xxx.xxx.xxx
          private_ip: xxx.xxx.xxx.xxx
          upstream_node_private_ip: xxx.xxx.xxx.xxx

How to include the tuning role in your Playbook

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

---
- hosts: pemserver,primary,standby
  name: Apply system and Postgres recommanded performance tuning
  become: true
  gather_facts: yes

  collections:
    - edb_devops.edb_postgres

  pre_tasks:
    - name: Initialize the user defined variables
      set_fact:
        pg_type: "PG"
        pg_version: 14

        ssd_disk: yes

  roles:
    - role: tuning

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: