I am reading this one:
Automatic Commit The easiest way to commit offsets is to allow the
consumer to do it for you. If you configure enable.auto.commit=true,
then every five seconds the consumer will commit the largest offset
your client received from poll(). The five-second interval is the
default and is controlled by setting auto.commit.interval.ms. Just
like everything else in the consumer, the automatic commits are driven
by the poll loop. Whenever you poll, the consumer checks if it is time
to commit, and if it is, it will commit the offsets it returned in the
last poll.
Maybe issue that my English is not good but I do not fully understood this description.
Let's say I use auto-commit with default interval - 5 sec and poll happens every 7 sec. At this case, a commit will happen every 5 sec or every 7 sec?
Can you clarify behaviour if poll will happen every 3 sec? Will commit happen every 5 sec or every 6 sec?
I have read this one:
Auto commits: You can set auto.commit to true and set the
auto.commit.interval.ms property with a value in milliseconds. Once
you've enabled this, the Kafka consumer will commit the offset of the
last message received in response to its poll() call. The poll() call
is issued in the background at the set auto.commit.interval.ms.
And it contradict the answer.
Can you explain this stuff in details.
let say I have diagramm like this:
0 sec - poll
4 sec - poll
8 sec - poll
When does offset will be committed and when which one?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…