Глава 49. Логическое декодирование
Содержание
- 49.1. Примеры логического декодирования
- 49.2. Концепции логического декодирования
- 49.3. Интерфейс протокола потоковой репликации
- 49.4. Интерфейс логического декодирования на уровне SQL
- 49.5. Системные каталоги, связанные с логическим декодированием
- 49.6. Модули вывода логического декодирования
- 49.4. Интерфейс логического декодирования на уровне SQL
- 49.7. Запись вывода логического декодирования
- 49.8. Поддержка синхронной репликации для логического декодирования
- 49.9. Передача больших транзакций для логического декодирования
- 49.10. Поддержка двухфазной фиксации для логического декодирования
PostgreSQL обеспечивает инфраструктуру для потоковой передачи изменений, выполняемых через SQL, внешним потребителям. Эта функциональность может быть полезна для самых разных целей, включая аудит и реализацию репликации.
Изменения передаются в потоках, связываемых со слотами логической репликации.
Формат, в котором передаются изменения, определяет используемый модуль вывода. Пример модуля вывода включён в дистрибутив PostgreSQL. Также возможно разработать и другие модули, расширяющие выбор доступных форматов, не затрагивая код ядра самого сервера. Любой модуль вывода получает на вход отдельные строки, создаваемые командой INSERT
, и новые версии строк, которые создаёт UPDATE
. Доступность старых версий строк для UPDATE
и DELETE
зависит от выбора варианта идентификации реплики (см. описание REPLICA IDENTITY
).
Изменения могут быть получены либо по протоколу потоковой репликации (см. Раздел 53.4 и Раздел 49.3), либо через функции, вызываемые в SQL (см. Раздел 49.4). Также возможно разработать дополнительные методы для обработки данных, поступающих через слот репликации, не модифицируя код ядра сервера (см. Раздел 49.7).