mirror of
https://github.com/matter-labs/ansible-en-role.git
synced 2025-12-06 10:59:56 +00:00
Compare commits
11 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| c5ab63672b | |||
| 22a1d06ef7 | |||
| 655b461ba5 | |||
| 45feed1069 | |||
| 5298e9f87d | |||
| 576f8eb252 | |||
| b672d803f0 | |||
| 5e8657ac3b | |||
| 4f1b6a37ab | |||
| 9034dc5fd4 | |||
| dac0b0cc80 |
@ -59,6 +59,9 @@ postgres_arguments:
|
|||||||
enable_postgres_replication: false
|
enable_postgres_replication: false
|
||||||
# IP address of the interface replication
|
# IP address of the interface replication
|
||||||
postgres_replications_arguments: []
|
postgres_replications_arguments: []
|
||||||
|
postgres_replica_user_name: ""
|
||||||
|
postgres_replica_user_password: ""
|
||||||
|
postgres_replica_auth_method: "scram-sha-256"
|
||||||
postgres_replication_bind_address: ""
|
postgres_replication_bind_address: ""
|
||||||
postgres_replica_address: ""
|
postgres_replica_address: ""
|
||||||
|
|
||||||
|
|||||||
@ -10,3 +10,6 @@ roles:
|
|||||||
collections:
|
collections:
|
||||||
- name: community.general
|
- name: community.general
|
||||||
version: 8.4.0
|
version: 8.4.0
|
||||||
|
# Collection for the replication only.
|
||||||
|
- name: community.postgresql
|
||||||
|
version: 3.7.0
|
||||||
|
|||||||
@ -9,3 +9,7 @@
|
|||||||
|
|
||||||
- name: Prepare configs
|
- name: Prepare configs
|
||||||
ansible.builtin.include_tasks: provision.yml
|
ansible.builtin.include_tasks: provision.yml
|
||||||
|
|
||||||
|
- name: Configure replication on main instance
|
||||||
|
ansible.builtin.include_tasks: replication.yml
|
||||||
|
when: enable_postgres_replication
|
||||||
|
|||||||
@ -46,6 +46,8 @@
|
|||||||
- postgres_replication_bind_address
|
- postgres_replication_bind_address
|
||||||
- postgres_replica_address
|
- postgres_replica_address
|
||||||
- postgres_replications_arguments
|
- postgres_replications_arguments
|
||||||
|
- postgres_replica_user_name
|
||||||
|
- postgres_replica_user_password
|
||||||
|
|
||||||
- name: Check required en vars empty
|
- name: Check required en vars empty
|
||||||
ansible.builtin.fail:
|
ansible.builtin.fail:
|
||||||
|
|||||||
42
tasks/replication.yml
Normal file
42
tasks/replication.yml
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
---
|
||||||
|
|
||||||
|
- name: Install libpq-dev packages
|
||||||
|
ansible.builtin.apt:
|
||||||
|
update_cache: true
|
||||||
|
name: libpq-dev
|
||||||
|
|
||||||
|
- name: Install psycopg2 python package
|
||||||
|
ansible.builtin.pip:
|
||||||
|
name: psycopg2
|
||||||
|
|
||||||
|
- name: Grant user replication access for replication.
|
||||||
|
community.postgresql.postgresql_pg_hba:
|
||||||
|
dest: "{{ storage_directory }}/postgres/pg_hba.conf"
|
||||||
|
contype: host
|
||||||
|
users: "{{ postgres_replica_user_name }}"
|
||||||
|
source: "{{ postgres_replica_address }}/32"
|
||||||
|
databases: replication
|
||||||
|
method: "{{ postgres_replica_auth_method }}"
|
||||||
|
|
||||||
|
- name: Create postgres replication user
|
||||||
|
community.postgresql.postgresql_user:
|
||||||
|
login_host: "{{ postgres_replication_bind_address }}"
|
||||||
|
login_user: "{{ database_username }}"
|
||||||
|
login_password: "{{ database_password }}"
|
||||||
|
name: "{{ postgres_replica_user_name }}"
|
||||||
|
password: "{{ postgres_replica_user_password }}"
|
||||||
|
role_attr_flags: "REPLICATION"
|
||||||
|
|
||||||
|
- name: Create replication slot if doesn't exist
|
||||||
|
community.postgresql.postgresql_slot:
|
||||||
|
login_host: "{{ postgres_replication_bind_address }}"
|
||||||
|
login_user: "{{ database_username }}"
|
||||||
|
login_password: "{{ database_password }}"
|
||||||
|
slot_name: replica
|
||||||
|
|
||||||
|
- name: Reload postgres configuration
|
||||||
|
community.postgresql.postgresql_query:
|
||||||
|
login_host: "{{ postgres_replication_bind_address }}"
|
||||||
|
login_user: "{{ database_username }}"
|
||||||
|
login_password: "{{ database_password }}"
|
||||||
|
query: "SELECT pg_reload_conf()"
|
||||||
@ -44,8 +44,6 @@ services:
|
|||||||
env_file:
|
env_file:
|
||||||
- postgres.env
|
- postgres.env
|
||||||
{% if enable_postgres_replication %}
|
{% if enable_postgres_replication %}
|
||||||
environment:
|
|
||||||
POSTGRES_HOST_AUTH_METHOD: "host replication replicator {{ postgres_replica_address }}/32 md5"
|
|
||||||
ports:
|
ports:
|
||||||
- "{{ postgres_replication_bind_address }}:5432:5432"
|
- "{{ postgres_replication_bind_address }}:5432:5432"
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|||||||
Reference in New Issue
Block a user