Class SourceTask
- All Implemented Interfaces:
- Task
- Direct Known Subclasses:
- MockSourceTask,- SchemaSourceTask,- VerifiableSourceTask
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumRepresents the permitted values for theTRANSACTION_BOUNDARY_CONFIGproperty.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe configuration key that determines how source tasks will define transaction boundaries when exactly-once support is enabled.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidcommit()This method is invoked periodically when offsets are committed for this source task.voidcommitRecord(SourceRecord record) Deprecated.voidcommitRecord(SourceRecord record, RecordMetadata metadata) Commit an individualSourceRecordwhen the callback from the producer client is received.voidinitialize(SourceTaskContext context) Initialize this SourceTask with the specified context object.abstract List<SourceRecord>poll()Poll this source task for new records.abstract voidStart the Task.abstract voidstop()Signal this SourceTask to stop.
- 
Field Details- 
TRANSACTION_BOUNDARY_CONFIGThe configuration key that determines how source tasks will define transaction boundaries when exactly-once support is enabled.- See Also:
 
 
- 
- 
Constructor Details- 
SourceTaskpublic SourceTask()
 
- 
- 
Method Details- 
initializeInitialize this SourceTask with the specified context object.
- 
startStart the Task. This should handle any configuration parsing and one-time setup of the task.
- 
pollPoll this source task for new records. If no data is currently available, this method should block but return control to the caller regularly (by returningnull) in order for the task to transition to thePAUSEDstate if requested to do so.The task will be stoppedon a separate thread, and when that happens this method is expected to unblock, quickly finish up any remaining processing, and return.- Returns:
- a list of source records
- Throws:
- InterruptedException
 
- 
commitThis method is invoked periodically when offsets are committed for this source task. Note that the offsets being committed won't necessarily correspond to the latest offsets returned by this source task viapoll(). Also seecommitRecord(SourceRecord, RecordMetadata)which allows for a more fine-grained tracking of records that have been successfully delivered.SourceTasks are not required to implement this functionality; Kafka Connect will record offsets automatically. This hook is provided for systems that also need to store offsets internally in their own system. - Throws:
- InterruptedException
 
- 
stoppublic abstract void stop()Signal this SourceTask to stop. In SourceTasks, this method only needs to signal to the task that it should stop trying to poll for new data and interrupt any outstanding poll() requests. It is not required that the task has fully stopped. Note that this method necessarily may be invoked from a different thread thanpoll()andcommit().For example, if a task uses a Selectorto receive data over the network, this method could set a flag that will forcepoll()to exit immediately and invokewakeup()to interrupt any ongoing requests.
- 
commitRecordDeprecated.UsecommitRecord(SourceRecord, RecordMetadata)instead.Commit an individual SourceRecordwhen the callback from the producer client is received. This method is also called when a record is filtered by a transformation, and thus will never be ACK'd by a broker.This is an alias for commitRecord(SourceRecord, RecordMetadata)for backwards compatibility. The default implementation ofcommitRecord(SourceRecord, RecordMetadata)just calls this method. It is not necessary to override both methods.SourceTasks are not required to implement this functionality; Kafka Connect will record offsets automatically. This hook is provided for systems that also need to store offsets internally in their own system. - Parameters:
- record-- SourceRecordthat was successfully sent via the producer or filtered by a transformation
- Throws:
- InterruptedException
 
- 
commitRecordCommit an individual SourceRecordwhen the callback from the producer client is received. This method is also called when a record is filtered by a transformation or when "errors.tolerance" is set to "all" and thus will never be ACK'd by a broker. In both casesmetadatawill be null.SourceTasks are not required to implement this functionality; Kafka Connect will record offsets automatically. This hook is provided for systems that also need to store offsets internally in their own system. The default implementation just calls commitRecord(SourceRecord), which is a nop by default. It is not necessary to implement both methods.- Parameters:
- record-- SourceRecordthat was successfully sent via the producer, filtered by a transformation, or dropped on producer exception
- metadata-- RecordMetadatarecord metadata returned from the broker, or null if the record was filtered or if producer exceptions are ignored
- Throws:
- InterruptedException
 
 
- 
commitRecord(SourceRecord, RecordMetadata)instead.