Глава 47. Логическое декодирование
Содержание
- 47.1. Примеры логического декодирования
- 47.2. Концепции логического декодирования
- 47.3. Интерфейс протокола потоковой репликации
- 47.4. Интерфейс логического декодирования на уровне SQL
- 47.5. Системные каталоги, связанные с логическим декодированием
- 47.6. Модули вывода логического декодирования
- 47.4. Интерфейс логического декодирования на уровне SQL
- 47.7. Запись вывода логического декодирования
- 47.8. Поддержка синхронной репликации для логического декодирования
- 47.9. Передача больших транзакций для логического декодирования
- 47.10. Поддержка двухфазной фиксации для логического декодирования
Postgres Pro обеспечивает инфраструктуру для потоковой передачи изменений, выполняемых через SQL, внешним потребителям. Эта функциональность может быть полезна для самых разных целей, включая аудит и реализацию репликации.
Изменения передаются в потоках, связываемых со слотами логической репликации.
Формат, в котором передаются изменения, определяет используемый модуль вывода. Пример модуля вывода включён в дистрибутив Postgres Pro. Также возможно разработать и другие модули, расширяющие выбор доступных форматов, не затрагивая код ядра самого сервера. Любой модуль вывода получает на вход отдельные строки, создаваемые командой INSERT
, и новые версии строк, которые создаёт UPDATE
. Доступность старых версий строк для UPDATE
и DELETE
зависит от выбора варианта идентификации реплики (см. описание REPLICA IDENTITY
).
Изменения могут быть получены либо по протоколу потоковой репликации (см. Раздел 53.4 и Раздел 47.3), либо через функции, вызываемые в SQL (см. Раздел 47.4). Также возможно разработать дополнительные методы для обработки данных, поступающих через слот репликации, не модифицируя код ядра сервера (см. Раздел 47.7).