This Ansible Galaxy Role Installs and configure PEM server.
Not all Distribution or versions are supported on all the operating systems available.
For more details refer to the: Database engines supported section.
Note: The role does not configure EDB Postgres Advanced Server or PostgreSQL for replication it only installs Postgres Enterprise Manager (PEM) and configures any node to be a PEM server.
The ansible playbook must be executed under an account that has full privileges.
The requirements for this ansible galaxy role are:
- Ansible >= 2.9
community.general
edb_devops.edb_postgres
->setup_repo
- for installing the EPAS/PG repositoryedb_devops.edb_postgres
->install_dbserver
- for installing the EPAS/PG binariesedb_devops.edb_postgres
->init_dbserver
- for initializing the EPAS/PG data directory and configuring a primary node.
When executing the role via ansible there are three required variables:
- pg_version
Postgres Versions supported are: 10, 11, 12 and 13
- pg_type
Database Engine supported are: PG and EPAS
The rest of the variables can be configured and are available in the:
The setup_pemserver
role does not have any dependencies on any other roles.
Content of the inventory.yml
file:
---
all:
children:
pemserver:
hosts:
pemserver1:
ansible_host: xxx.xxx.xxx.xxx
private_ip: xxx.xxx.xxx.xxx
primary:
hosts:
primary1:
ansible_host: xxx.xxx.xxx.xxx
private_ip: xxx.xxx.xxx.xxx
pem_agent: true
pem_server_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
replication_type: synchronous
pem_agent: true
pem_server_private_ip: xxx.xxx.xxx.xxx
standby2:
ansible_host: xxx.xxx.xxx.xxx
private_ip: xxx.xxx.xxx.xxx
upstream_node_private_ip: xxx.xxx.xxx.xxx
replication_type: asynchronous
pem_agent: true
pem_server_private_ip: xxx.xxx.xxx.xxx
Below is an example of how to include the setup_pemserver
role:
---
- hosts: pemserver
name: Setup PEM server
become: yes
gather_facts: yes
collections:
- edb_devops.edb_postgres
pre_tasks:
- name: Initialize the user defined variables
set_fact:
pg_version: 13
pg_type: "PG"
roles:
- setup_pemserver
Defining and adding variables is done in the set_fact
of the pre_tasks
.
All the variables are available at:
- roles/setup_pemserver/defaults/main.yml
- roles/setup_pemserver/vars/EPAS.yml
- roles/setup_pemserver/vars/PG.yml
Distribution | 10 | 11 | 12 | 13 |
---|---|---|---|---|
CentOS 7 | ✅ | ✅ | ✅ | ✅ |
Red Hat Linux 7 | ✅ | ✅ | ✅ | ✅ |
CentOS 8 | ✅ | ✅ | ✅ | ✅ |
Red Hat Linux 8 | ✅ | ✅ | ✅ | ✅ |
Distribution | 10 | 11 | 12 |
---|---|---|---|
CentOS 7 | ✅ | ✅ | ✅ |
Red Hat Linux 7 | ✅ | ✅ | ✅ |
CentOS 8 | ❌ | ❌ | ✅ |
Red Hat Linux 8 | ❌ | ❌ | ✅ |
- ✅ - Tested and supported
- ❌ - Not supported
# To deploy community Postgres version 13 with the user centos
$ ansible-playbook playbook.yml \
-u centos \
-i inventory.yml \
--private-key <key.pem> \
--extra-vars="pg_version=13 pg_type=PG"
# To deploy EPAS version 12 with the user ec2-user
$ ansible-playbook playbook.yml \
-u ec2-user \
-i inventory.yml \
--private-key <key.pem> \
--extra-vars="pg_version=12 pg_type=EPAS"
BSD
Author:
- Doug Ortiz
- Vibhor Kumar (Co-Author)
- EDB Postgres
- DevOps
- [email protected] www.enterprisedb.com