Глава 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. Поддержка двухфазной фиксации для логического декодирования
Postgres Pro Shardman обеспечивает инфраструктуру для потоковой передачи изменений, выполняемых через SQL, внешним потребителям. Эта функциональность может быть полезна для самых разных целей, включая аудит и реализацию репликации.
Изменения передаются в потоках, связываемых со слотами логической репликации.
Формат, в котором передаются изменения, определяет используемый модуль вывода. Пример модуля вывода включён в дистрибутив Postgres Pro Shardman. Также возможно разработать и другие модули, расширяющие выбор доступных форматов, не затрагивая код ядра самого сервера. Любой модуль вывода получает на вход отдельные строки, создаваемые командой INSERT
, и новые версии строк, которые создаёт UPDATE
. Доступность старых версий строк для UPDATE
и DELETE
зависит от выбора варианта идентификации реплики (см. описание REPLICA IDENTITY
).
Изменения могут быть получены либо по протоколу потоковой репликации (см. Раздел 56.4 и Раздел 49.3), либо через функции, вызываемые в SQL (см. Раздел 49.4). Также возможно разработать дополнительные методы для обработки данных, поступающих через слот репликации, не модифицируя код ядра сервера (см. Раздел 49.7).