mirror of
https://github.com/matter-labs/ansible-en-role.git
synced 2025-12-06 02:49:55 +00:00
feat: Configure replication from postgres collection
This commit is contained in:
@ -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: ""
|
||||||
|
|
||||||
|
|||||||
@ -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:
|
||||||
|
|||||||
34
tasks/replication.yml
Normal file
34
tasks/replication.yml
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
---
|
||||||
|
- name: Grant user replication from network 192.168.0.100/24 access for replication with client cert authentication
|
||||||
|
community.postgresql.postgresql_pg_hba:
|
||||||
|
dest: {{ storage_directory }}/postgres/pg_hba.conf
|
||||||
|
contype: host
|
||||||
|
users: replication
|
||||||
|
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_user: {{ database_username }}
|
||||||
|
name: {{ postgres_replica_user_name }}
|
||||||
|
password: {{ postgres_replica_user_password }}
|
||||||
|
priv: "REPLICATION"
|
||||||
|
|
||||||
|
|
||||||
|
- name: Create replication slot if doesn't exist
|
||||||
|
become_user: postgres
|
||||||
|
community.postgresql.postgresql_slot:
|
||||||
|
login_host: {{ postgres_replication_bind_address }}
|
||||||
|
login_user: {{ database_username }}
|
||||||
|
login_user: {{ database_username }}
|
||||||
|
slot_name: replica
|
||||||
|
|
||||||
|
- name: Reload postgres select query to acme db
|
||||||
|
community.postgresql.postgresql_query:
|
||||||
|
login_host: {{ postgres_replication_bind_address }}
|
||||||
|
login_user: {{ database_username }}
|
||||||
|
login_user: {{ database_username }}
|
||||||
|
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