Decode Logical Decoding Message Content
The DecodeLogicalDecodingMessageContent SMT converts the binary content of a PostgreSQL logical decoding message to a structured form.
When the Debezium PostgreSQL connector captures logical decoding messages, it emits message event records to Kafka.
By default, the content field in these message records contain encoded binary data.
To facilitate processing of PostgreSQL event messages by other Kafka consumers, you can use the DecodeLogicalDecodingMessageContent SMT to decode the binary content of the original message, and convert it into a more consumable format.
You also use the SMT in conjunction with other SMTs, such as the Debezium Outbox Event Router.
Example
To enable a Debezium PostgreSQL connector to decode the binary content in message events, add the DecodeLogicalDecodingMessageContent SMT to the Kafka Connect configuration for the connector, as shown in the following example:
"connector.class": "io.debezium.connector.postgresql.PostgresConnector",
...
"transforms": "decodeLogicalDecodingMessageContent",
"transforms.decodeLogicalDecodingMessageContent.type": "io.debezium.connector.postgresql.transforms.DecodeLogicalDecodingMessageContent",
"key.converter": "org.apache.kafka.connect.json.JsonConverter",
"key.converter.schemas.enable": false,
"value.converter": "org.apache.kafka.connect.json.JsonConverter",
"value.converter.schemas.enable": "false",
...
The following example shows the key and value of an event record before and after the transformation is applied.
DecodeLogicalDecodingMessageContent SMT- Event key before the SMT processes the record
-
{ "prefix": "test-prefix" (1) } - Event value before the SMT processes the record
-
{ "op": "m", (2) "ts_ms": 1723115240065, "source": { "version": "3.0.0-SNAPSHOT", "connector": "postgresql", "name": "connector-name", "ts_ms": 1723115239782, "snapshot": "false", "db": "source-db", "sequence": "[\"26997744\",\"26997904\"]", "ts_us": 1723115239782690, "ts_ns": 1723115239782690000, "schema": "", "table": "", "txId": 756, "lsn": 26997904, "xmin": null }, "message": { (3) "prefix": "test-prefix", "content": "eyJpZCI6IDEsICJpdGVtIjogIkRlYmV6aXVtIGluIEFjdGlvbiIsICJzdGF0dXMiOiAiRU5URVJFRCIsICJxdWFudGl0eSI6IDIsICJ0b3RhbFByaWNlIjogMzkuOTh9" } }
- Event key after the SMT processes the record
null (1)
- Event value after the SMT processes the record
-
{ "op": "c", (2) "ts_ms": 1723115415729, "source": { "version": "3.0.0-SNAPSHOT", "connector": "postgresql", "name": "connector-name", "ts_ms": 1723115415640, "snapshot": "false", "db": "source-db", "sequence": "[\"26717416\",\"26717576\"]", "ts_us": 1723115415640161, "ts_ns": 1723115415640161000, "schema": "", "table": "", "txId": 745, "lsn": 26717576, "xmin": null }, "after": { (3) "id": 1, "item": "Debezium in Action", "status": "ENTERED", "quantity": 2, "totalPrice": 39.98 } }
In the preceding example, the SMT applies the following changes to the original event record:
-
Removes the key that contained the
prefixfield in the original logical decoding message ("prefix": "test-prefix"). -
Converts the value of the
opfield from anm(message) to ac(create), effectively changing the event type frommessagetoINSERT. -
Replaces the
messagefield with anafterfield that contains the decoded content of a logical decoding message.
After the SMT applies these changes, the record can be more easily processed by downstream consumers or by other SMTs, such as the Debezium Outbox Event Router.
Configuration options
The following table lists the configuration options that you can use with the DecodeLogicalDecodingMessageContent SMT.
Property |
Type |
Default |
Description |
boolean |
|
Specifies how the decoding process handles fields that have |