Class KafkaItemReader<K,V> 
java.lang.Object
org.springframework.batch.item.ItemStreamSupport
org.springframework.batch.item.support.AbstractItemStreamItemReader<V>
org.springframework.batch.item.kafka.KafkaItemReader<K,V> 
- All Implemented Interfaces:
- ItemReader<V>,- ItemStream,- ItemStreamReader<V>
 An ItemReader implementation for Apache Kafka.
 Uses a KafkaConsumer to read data from a given topic. Multiple partitions
 within the same topic can be assigned to this reader.
 
 Since KafkaConsumer is not thread-safe, this reader is not thread-safe.
 
- Since:
- 4.2
- Author:
- Mathieu Ouellet, Mahmoud Ben Hassine
- 
Constructor SummaryConstructorsConstructorDescriptionKafkaItemReader(Properties consumerProperties, String topicName, Integer... partitions) Create a newKafkaItemReader.KafkaItemReader(Properties consumerProperties, String topicName, List<Integer> partitions) Create a newKafkaItemReader.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclose()No-op.booleanThe flag that determines whether to save internal state for restarts.voidopen(ExecutionContext executionContext) No-op.read()Reads a piece of input data and advance to the next one.voidsetPartitionOffsets(Map<org.apache.kafka.common.TopicPartition, Long> partitionOffsets) Setter for partition offsets.voidsetPollTimeout(Duration pollTimeout) Set a timeout for the consumer topic polling duration.voidsetSaveState(boolean saveState) Set the flag that determines whether to save internal data forExecutionContext.voidupdate(ExecutionContext executionContext) Return emptyExecutionContext.Methods inherited from class org.springframework.batch.item.ItemStreamSupportgetExecutionContextKey, setExecutionContextName, setName
- 
Constructor Details- 
KafkaItemReaderCreate a newKafkaItemReader.
 .consumerPropertiesmust contain the following keys: 'bootstrap.servers', 'group.id', 'key.deserializer' and 'value.deserializer'- Parameters:
- consumerProperties- properties of the consumer
- topicName- name of the topic to read data from
- partitions- list of partitions to read data from
 
- 
KafkaItemReaderCreate a newKafkaItemReader.
 .consumerPropertiesmust contain the following keys: 'bootstrap.servers', 'group.id', 'key.deserializer' and 'value.deserializer'- Parameters:
- consumerProperties- properties of the consumer
- topicName- name of the topic to read data from
- partitions- list of partitions to read data from
 
 
- 
- 
Method Details- 
setPollTimeoutSet a timeout for the consumer topic polling duration. Default to 30 seconds.- Parameters:
- pollTimeout- for the consumer poll operation
 
- 
setSaveStatepublic void setSaveState(boolean saveState) Set the flag that determines whether to save internal data forExecutionContext. Only switch this to false if you don't want to save any state from this stream, and you don't need it to be restartable. Always set it to false if the reader is being used in a concurrent environment.- Parameters:
- saveState- flag value (default true).
 
- 
isSaveStatepublic boolean isSaveState()The flag that determines whether to save internal state for restarts.- Returns:
- true if the flag was set
 
- 
setPartitionOffsetsSetter for partition offsets. This mapping tells the reader the offset to start reading from in each partition. This is optional, defaults to starting from offset 0 in each partition. Passing an empty map makes the reader start from the offset stored in Kafka for the consumer group ID.In case of a restart, offsets stored in the execution context will take precedence. - Parameters:
- partitionOffsets- mapping of starting offset in each partition
 
- 
openDescription copied from class:ItemStreamSupportNo-op.- Specified by:
- openin interface- ItemStream
- Overrides:
- openin class- ItemStreamSupport
- Parameters:
- executionContext- current step's- ExecutionContext. Will be the executionContext from the last run of the step on a restart.
- See Also:
 
- 
readDescription copied from interface:ItemReaderReads a piece of input data and advance to the next one. Implementations must returnnullat the end of the input data set. In a transactional setting, caller might get the same item twice from successive calls (or otherwise), if the first call was in a transaction that rolled back.- Returns:
- T the item to be processed or nullif the data source is exhausted
 
- 
updateDescription copied from class:ItemStreamSupportReturn emptyExecutionContext.- Specified by:
- updatein interface- ItemStream
- Overrides:
- updatein class- ItemStreamSupport
- Parameters:
- executionContext- to be updated
- See Also:
 
- 
closepublic void close()Description copied from class:ItemStreamSupportNo-op.- Specified by:
- closein interface- ItemStream
- Overrides:
- closein class- ItemStreamSupport
- See Also:
 
 
-