Modifier and Type | Field and Description |
---|---|
protected SourceTaskContext |
context |
Constructor and Description |
---|
SourceTask() |
Modifier and Type | Method and Description |
---|---|
void |
commit()
Commit the offsets, up to the offsets that have been returned by
poll() . |
void |
commitRecord(SourceRecord record)
Commit an individual
SourceRecord when the callback from the producer client is received. |
void |
commitRecord(SourceRecord record,
RecordMetadata metadata)
Commit an individual
SourceRecord when the callback from the producer client is received. |
void |
initialize(SourceTaskContext context)
Initialize this SourceTask with the specified context object.
|
abstract List<SourceRecord> |
poll()
Poll this source task for new records.
|
abstract void |
start(Map<String,String> props)
Start the Task.
|
abstract void |
stop()
Signal this SourceTask to stop.
|
protected SourceTaskContext context
public void initialize(SourceTaskContext context)
public abstract void start(Map<String,String> props)
public abstract List<SourceRecord> poll() throws InterruptedException
Poll this source task for new records. If no data is currently available, this method
should block but return control to the caller regularly (by returning null
) in
order for the task to transition to the PAUSED
state if requested to do so.
The task will be stopped
on a separate thread, and when that happens
this method is expected to unblock, quickly finish up any remaining processing, and
return.
InterruptedException
public void commit() throws InterruptedException
Commit the offsets, up to the offsets that have been returned by poll()
. This
method should block until the commit is complete.
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.
InterruptedException
public abstract void stop()
poll()
and
commit()
.
For example, if a task uses a Selector
to receive data over the network, this method
could set a flag that will force poll()
to exit immediately and invoke
wakeup()
to interrupt any ongoing requests.public void commitRecord(SourceRecord record) throws InterruptedException
Commit an individual SourceRecord
when 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 of commitRecord(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.
record
- SourceRecord
that was successfully sent via the producer or filtered by a transformationInterruptedException
commitRecord(SourceRecord, RecordMetadata)
public void commitRecord(SourceRecord record, RecordMetadata metadata) throws InterruptedException
Commit an individual SourceRecord
when 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. In this case
metadata
will 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 @{link commitRecord(SourceRecord)}, which is a nop by default. It is not necessary to implement both methods.
record
- SourceRecord
that was successfully sent via the producer or filtered by a transformationmetadata
- RecordMetadata
record metadata returned from the broker, or null if the record was filteredInterruptedException