fruworg.github.io/content/posts/postgres-replication.md
root c793b55750 Revert "remove shell"
This reverts commit 65914f8895a7183915bb9484a725085cd24038f1.
2023-09-24 18:58:33 +03:00

3.2 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

Дописываем в конец файла:

host    replication    repuser    <slave-ip>/32    md5

# /var/lib/pgpro/std-13/data/pg_hba.conf

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

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

# /var/lib/pgpro/std-13/data/postgresql.conf

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

systemctl restart postgres

Настройка slave

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

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

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

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

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

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

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

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

# /var/lib/pgpro/std-13/data/postgresql.conf

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

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

synchronous_commit = on
synchronous_standby_names = 'pgsql_0_node_0'

# /var/lib/pgpro/std-13/data/postgresql.conf