pg_standby. Создание сервера «теплого» резерва#
В исходном дистрибутиве установлено по умолчанию: да.
Связанные компоненты: отсутствуют.
Схема размещения: не используется.
Программа pg_standby поддерживает создание сервера и предназначена для:
применения в производственной среде;
использования в качестве настраиваемой заготовки, когда требуются специальные модификации.
pg_standby ожидает выполнения команды restore_command, которая нужна для перехода от стандартного восстановления архива к режиму так называемого «теплого» резерва.
Его настройка описана в разделе 27.2.4 документации оригинальной PostgreSQL.
Синтаксис:
pg_standby [параметр...] расположение_архива следующий_файл_wal каталог_wal [файл_перезапуска_wal]
Если указывается файл_перезапуска_wal, тогда все файлы журнала предзаписи (WAL), предшествующие указанному, будут удалены из каталога расположение_архива. Аргумент обычно указывается с помощью макроса %r.
Удаление предыдущих журналов позволяет сократить число сохраняемых файлов без потери возможности восстановления при перезапуске. Такой вариант использования уместен, когда расположение_архива указывает на область рабочих файлов конкретного резервного сервера, но не когда расположение_архива — это каталог с архивом WAL для долговременного хранения.
Логика работы приложения pg_standby предполагает, что каталог, заданный аргументом расположение_архива, доступен для чтения владельцу серверного процесса.
Кроме того, если указывается аргумент файл_перезапуска_wal (или ключ -k), то каталог расположение_архива должен быть доступен для записи.
При выходе из строя ведущего сервера переключение на сервер «теплого резерва» возможно двумя способами:
Умное переключение (Smart Failover).
При умном переключении сервер включается в работу, применив изменения из всех файлов WAL, имеющихся в архиве. В результате умного переключения данные не теряются, даже если данный резервный сервер отстал. Если применить нужно большое количество изменений WAL, подготовка к работе может быть длительной. Чтобы вызвать умное переключение, нужно создать файл-триггер, содержащий слово
smart, либо просто пустой файл.Быстрое переключение (Fast Failover).
При быстром переключении сервер включается в работу немедленно. Все не примененные файлы WAL в архиве будут игнорироваться, и все транзакции в этих файлах будут потеряны. Чтобы вызвать быстрое переключение, создайте файл-триггер и запишите в него слово
fast. Программуpg_standbyможно настроить так, чтобы быстрое переключение происходило автоматически, если за определенное время не появляется новый файл журнала WAL.
Параметры
Расширение pg_standby принимает следующие аргументы командной строки:
Аргумент |
Описание |
|---|---|
|
Применяет для восстановления файлов WAL из архива команду |
|
Выводит подробные отладочные сообщения в |
|
Задает количество файлов WAL, предшествующих текущему журналу; параметр оставляет не больше заданного числа файлов WAL в каталоге |
|
Устанавливает максимальное количество повторов команды |
|
Задает количество секунд для выдержки паузы между проверками наличия файла WAL в архиве. |
|
Указывает файл-триггер, при появлении которого должна начаться отработка отказа. Имя этого файла рекомендуется выбирать по определенной схеме, позволяющей однозначно понять, для какого сервера вызывается отработка отказа, когда таких серверов в одной системе несколько. Например, |
|
Выводит версию |
|
Задает максимальное время ожидания (в секундах) следующего файла WAL, по истечении которого будет произведено быстрое переключение. |
|
Выводит справку об аргументах командной строки |
Доработка#
Доработка не проводилась.
Ограничения#
Программа pg_standby предназначена для работы с ядром СУБД PostgreSQL версии 8.2 или новее.
Установка#
Установка не требуется.
Исполняемый файл pg_standby расположен в каталоге $PGHOME/bin/.
Настройка#
Чтобы настроить резервный сервер на использование pg_standby, поместите в файл конфигурации резервного сервера $PGDATA/postgresql.conf строку:
restore_command = 'pg_standby каталог_архива %f %p %r'
где каталог_архива — каталог, из которого должны восстанавливаться сегменты журнала предзаписи (WAL).
Использование модуля#
В операционных системах семейства Unix можно использовать команды:
archive_command = 'cp %p .../archive/%f'
restore_command = 'pg_standby -d -s 2 -t /tmp/pgsql.trigger.5442 .../archive %f %p %r 2>>standby.log'
recovery_end_command = 'rm -f /tmp/pgsql.trigger.5442'
Предполагается, что каталог архива физически располагается на резервном сервере. Команда archive_command обращается к резервному серверу посредством сетевого доступа. По отношению к самому резервному серверу эти файлы будут являться локальными, для чего применяется создание ссылок (ln).
Приведенные выше команды будут выполнять действия:
выводить отладочную информацию в
standby.log;ждать 2 секунды между проверками появления следующего файла WAL;
прекращать ожидание, только когда появляется файл-триггер с именем
/tmp/pgsql.trigger.5442, и выполнять переключение согласно его содержимому;удалять файл-триггер после завершения восстановления;
удалять лишние файлы из каталога архива.
Ссылки на документацию разработчика#
Дополнительно поставляемый модуль pg_standby: https://www.postgresql.org/docs/15/pgstandby.html.