fruworg.github.io/content/posts/postgres-replication.md
2023-10-13 03:23:27 +06:00

3.4 KiB
Raw Blame History

title description date tags
Настройка физической репликации Postgres Pro Потоковая репликация и репликация с архивом 2022-11-25T16:51:00+05:00
linux
postgres
nfs

Установка Postgres Pro

Процесс установки описан в этом посте.

Потоковая репликация

Про различия в реализациях репликаций можно почитать вот здесь.

Конфигурация master

Действия с Postgres Pro следует выполнять от имени пользователя postgres.

su - postgres

Создание пользователя для репликации

psql -c "CREATE ROLE repuser WITH REPLICATION LOGIN ENCRYPTED PASSWORD '<password>';"

Разрешение подключения для slave

Дописываем в конец файла /var/lib/pgpro/std-*/data/pg_hba.conf:

host    replication    repuser    <slave-ip>/32    md5

Реконфигурация

В файл /var/lib/pgpro/std-13/data/postgresql.conf необходимо добавить следующие строки:

listen_addresses = 'localhost, <master-ip>'
wal_level = hot_standby
archive_mode = on
archive_command = 'cd .'
max_wal_senders = 8
hot_standby = on

Перезапуск Postgres Pro

systemctl restart postgres*

Настройка slave

Выгрузка файлов с master

rm -rf /var/lib/pgpro/std-*/data/*
pg_basebackup -P -R -X stream -c fast -h <master-ip> -U postgres -D /var/lib/pgpro/std-*/data

Репликация с архивом

Настройка репликации с архивом выролняется с некоторыми отличиями от потоковой репликации:

Развёртывание NFS

WAL-архивы будут складываться на NFS. Как сконфигурировать NFS написано здесь. Необходимо смонтировать NFS на master и slave в одинаковые директории.

Дополнение к реконфигурации

В файл /var/lib/pgpro/std-*/data/postgresql.conf необходимо добавить следующие строки:

archive_command = 'test ! -f /nfs/%f && cp %p /nfs/%f'
archive_cleanup_command = 'pg_archivecleanup -d /nfs %r 2>>cleanup.log'

Синхронный и асинхронный режим репликации

При синхронной репликации, изменения применятся на основном сервере только после того, как они запишутся в WAL хотя бы одной реплики, а при асинхронной - сразу. По умолчанию репликация работает в асинхронном режиме. Для того, чтобы она работала в синхронном режиме, необходимо изменить две строки в конфигурационном файле Postgres Pro /var/lib/pgpro/std-*/data/postgresql.conf:

synchronous_commit = on
synchronous_standby_names = 'pgsql_0_node_0'