В этом разделе подробно описывается формат каждого сообщения логической репликации. Эти сообщения или выдаются через SQL-интерфейс слота репликации или передаются процессом walsender. Когда их передаёт walsender, они помещаются внутрь WAL-сообщений протокола репликации, описанных в Разделе 53.4, и в общем следуют тому же потоку сообщений, что и сообщения физической репликации.
Указывает, что это начальное сообщение.
Окончательный LSN транзакции.
Время фиксации транзакции. Значение задаётся в микросекундах, прошедших с начала эпохи PostgreSQL (2000-01-01).
Идентификатор транзакции.
Указывает, что это сообщение логического декодирования.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Флаги; либо 0, если флагов нет, либо 1, если сообщение логического декодирования передано как транзакционное.
LSN сообщения логического декодирования.
Префикс сообщения логического декодирования.
Длина содержимого сообщения.
nСодержание сообщения логического декодирования.
Указывает, что это сообщение о фиксации.
Флаги; в настоящее время не используются (поле должно содержать 0).
LSN записи фиксации.
Конечный LSN транзакции.
Время фиксации транзакции. Значение задаётся в микросекундах, прошедших с начала эпохи PostgreSQL (2000-01-01).
Указывает, что это сообщение об источнике.
LSN записи фиксации на сервере-источнике.
Имя источника.
Заметьте, что внутри одной транзакции может быть несколько сообщений Origin.
Указывает, что это сообщение об отношении.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Идентификатор отношения.
Пространство имён (пустая строка для pg_catalog).
Имя отношения.
Свойство идентификации реплики для отношения (то же, что и relreplident в pg_class).
Число столбцов.
Затем для каждого столбца (за исключением генерируемых) идёт следующий блок сообщения:
Флаги столбца. В настоящее время это может быть 0 (флагов нет) или 1 (столбец помечается как часть ключа).
Имя столбца.
Идентификатор типа данных столбца.
Модификатор типа столбца (atttypmod).
Указывает, что это сообщение о типе.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Идентификатор типа данных.
Пространство имён (пустая строка для pg_catalog).
Имя типа данных.
Указывает, что это сообщение о добавлении данных.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Идентификатор отношения, соответствующий идентификатору в сообщении об отношении.
Обозначает следующее сообщение TupleData как содержащее новый кортеж.
Блок сообщения TupleData, представляющий содержимое нового кортежа.
Указывает, что это сообщение об изменении данных.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Идентификатор отношения, соответствующий идентификатору в сообщении об отношении.
Указывает, что следующий блок TupleData содержит ключ. Это поле является необязательным и присутствует, только если изменение затронуло столбцы, являющиеся частью индекса REPLICA IDENTITY.
Указывает, что следующий блок TupleData содержит старый кортеж. Это поле является необязательным и присутствует, только если у таблицы, в которой произошло изменение, свойство REPLICA IDENTITY равно FULL.
Блок сообщения TupleData, представляющий содержимое старого кортежа или первичного ключа. Присутствует, только если перед ним идёт признак 'O' или 'K'.
Обозначает следующее сообщение TupleData как содержащее новый кортеж.
Блок сообщения TupleData, представляющий содержимое нового кортежа.
Сообщение Update может содержать либо блок 'K', либо блок 'O', либо ни один из них, но не оба сразу.
Указывает, что это сообщение об удалении данных.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Идентификатор отношения, соответствующий идентификатору в сообщении об отношении.
Указывает, что следующий блок TupleData содержит ключ. Это поле присутствует, если таблица, в которой произошло удаление, использует индекс в качестве REPLICA IDENTITY.
Указывает, что следующий блок TupleData содержит старый кортеж. Это поле присутствует, если у таблицы, в которой произошло удаление, свойство REPLICA IDENTITY равно FULL.
Блок сообщения TupleData, представляющий содержимое старого кортежа или первичного ключа, в зависимости от предыдущего поля.
Сообщение Delete может содержать либо блок 'K', либо блок 'O', но не оба сразу.
Указывает, что это сообщение об усечении отношений.
Идентификатор транзакции (только для транзакций, передаваемых потоками). Это поле присутствует со 2-й версии протокола.
Число отношений.
Битовые флаги для TRUNCATE: 1 соответствует указанию CASCADE, 2 — RESTART IDENTITY.
Идентификатор отношения, соответствующий идентификатору в сообщении об отношении. Это поле повторятся для каждого отношения.
Описанные ниже сообщения Stream Start, Stream Stop, Stream Commit и Stream Abort доступны со 2-й версии протокола.
Указывает, что это сообщение о начале потока.
Идентификатор транзакции.
1 означает, что это первый сегмент потока с этим идентификатором; 0, если это любой другой сегмент.
Указывает, что это сообщение об окончании потока.
Указывает, что это сообщение о фиксации транзакции в потоке.
Идентификатор транзакции.
Флаги; в настоящее время не используются (поле должно содержать 0).
LSN записи фиксации.
Конечный LSN транзакции.
Время фиксации транзакции. Значение задаётся в микросекундах, прошедших с начала эпохи PostgreSQL (2000-01-01).
Указывает, что это сообщение о прерывании транзакции в потоке.
Идентификатор транзакции.
Идентификатор подтранзакции (для транзакций верхнего уровня совпадает с идентификатором транзакции).
Описанные выше сообщения имеют следующие общие блоки.
Число столбцов.
Затем для каждого столбца (за исключением генерируемых) идёт одно из следующих вложенных сообщений:
Обозначает данные как значение NULL.
Или
Обозначает неизменённое значение TOAST (само значение не передаётся).
Или
Обозначает данные как значение в текстовом формате.
Или
Обозначает данные как значение в двоичном формате.
Длина значения столбца.
nЗначение столбца в двоичном или текстовом формате, определённом предшествующим байтом формата. Переменная n задаёт длину значения.