Class DebeziumMessageProducerSpec
java.lang.Object
org.springframework.integration.dsl.IntegrationComponentSpec<DebeziumMessageProducerSpec, DebeziumMessageProducer>
org.springframework.integration.dsl.MessageProducerSpec<DebeziumMessageProducerSpec, DebeziumMessageProducer>
org.springframework.integration.debezium.dsl.DebeziumMessageProducerSpec
- All Implemented Interfaces:
- DisposableBean,- FactoryBean<DebeziumMessageProducer>,- InitializingBean,- Lifecycle,- Phased,- SmartLifecycle
public class DebeziumMessageProducerSpec
extends MessageProducerSpec<DebeziumMessageProducerSpec, DebeziumMessageProducer>
- Since:
- 6.2
- Author:
- Christian Tzolov, Artem Bilan
- 
Field SummaryFields inherited from class org.springframework.integration.dsl.IntegrationComponentSpeclogger, PARSER, targetFields inherited from interface org.springframework.beans.factory.FactoryBeanOBJECT_TYPE_ATTRIBUTEFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDebeziumMessageProducerSpec(io.debezium.engine.DebeziumEngine.Builder<io.debezium.engine.ChangeEvent<byte[], byte[]>> debeziumEngineBuilder) 
- 
Method SummaryModifier and TypeMethodDescriptioncontentType(String contentType) Set the outbound message content type.enableBatch(boolean enable) Enable theChangeEventbatch mode handling.enableEmptyPayload(boolean enabled) Enable support for tombstone (aka delete) messages.headerMapper(HeaderMapper<List<io.debezium.engine.Header<Object>>> headerMapper) headerNames(String... headerNames) Comma-separated list of names ofChangeEventheaders to be mapped into outbound Message headers.taskExecutor(TaskExecutor taskExecutor) Set aTaskExecutorfor the Debezium engine.Methods inherited from class org.springframework.integration.dsl.MessageProducerSpecautoStartup, errorChannel, errorChannel, errorMessageStrategy, id, observationConvention, outputChannel, outputChannel, phase, role, sendTimeout, shouldTrackMethods inherited from class org.springframework.integration.dsl.IntegrationComponentSpec_this, afterPropertiesSet, destroy, doGet, getId, getObject, getObjectType, getPhase, isAutoStartup, isRunning, start, stop, stopMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.beans.factory.FactoryBeanisSingletonMethods inherited from interface org.springframework.context.SmartLifecycleisPauseable
- 
Constructor Details- 
DebeziumMessageProducerSpecprotected DebeziumMessageProducerSpec(io.debezium.engine.DebeziumEngine.Builder<io.debezium.engine.ChangeEvent<byte[], byte[]>> debeziumEngineBuilder) 
 
- 
- 
Method Details- 
enableBatchEnable theChangeEventbatch mode handling. When enabled the channel adapter will send aListofChangeEvents as a payload in a single downstreamMessage. Such a batch payload is not serializable. By default, the batch mode is disabled, e.g. every inputChangeEventis converted into a single downstreamMessage.- Parameters:
- enable- set to true to enable the batch mode. Disabled by default.
- Returns:
- the spec.
 
- 
enableEmptyPayloadEnable support for tombstone (aka delete) messages. On a database row delete, Debezium can send a tombstone change event that has the same key as the deleted row and a value ofOptional.empty(). This record is a marker for downstream processors. It indicates that log compaction can remove all records that have this key. When the tombstone functionality is enabled in the Debezium connector configuration you should enable the empty payload as well.- Parameters:
- enabled- set true to enable the empty payload. Disabled by default.
- Returns:
- the spec.
 
- 
taskExecutorSet aTaskExecutorfor the Debezium engine.- Parameters:
- taskExecutor- the- TaskExecutorto use.
- Returns:
- the spec.
 
- 
contentTypeSet the outbound message content type. Must be aligned with theSerializationFormatconfiguration used by the providedDebeziumEngine.- Parameters:
- contentType- payload content type.
- Returns:
- the spec.
 
- 
headerNamesComma-separated list of names ofChangeEventheaders to be mapped into outbound Message headers. Debezium's NewRecordStateExtraction 'add.headers' property configures the metadata to be used asChangeEventheaders.You should prefix the names passed to the 'headerNames' with the prefix configured by the Debezium 'add.headers.prefix' property. Later defaults to '__'. For example for 'add.headers=op,name' and 'add.headers.prefix=__' you should use header hames like: '__op', '__name'. - Parameters:
- headerNames- The values in this list can be a simple patterns to be matched against the header names.
- Returns:
- the spec.
 
- 
headerMapperpublic DebeziumMessageProducerSpec headerMapper(HeaderMapper<List<io.debezium.engine.Header<Object>>> headerMapper) - Parameters:
- headerMapper-- HeaderMapperimplementation to use. Defaults to- DefaultDebeziumHeaderMapper.
- Returns:
- the spec.
 
 
-