如何更改主题的起始偏移量?

时间:2015-04-22 08:01:49

标签: apache-kafka

可以更改新主题的起始偏移量吗?我想创建一个新主题,并从偏移10000开始阅读。怎么样?

4 个答案:

答案 0 :(得分:23)

由于kafka 0.11.0.0您可以使用脚本kafka-consumer-groups.sh 来自this answer

的示例
kafka-consumer-groups.sh --bootstrap-server kafka-host:9092 --group my-group --reset-offsets --to-earliest --all-topics --execute

KIP-122: Add Reset Consumer Group Offsets tooling

中列出的其他选项
.----------------------.-----------------------------------------------.----------------------------------------------------------------------------------------------------------------------------------------------.
|      Scenario        |                   Arguments                   |                                                                    Example                                                                   |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset to Datetime    |  --to-datetime YYYY-MM-DDTHH:mm:SS.sss±hh:mm  |  Reset to first offset since 01 January 2017, 00:00:00 hrs: --reset-offsets –group test.group --topic foo --to-datetime 2017-01-01T00:00:00Z |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset by Duration    |  --by-duration  PnDTnHnMnS                    |  Reset to first offset since one week ago (from current timestamp): --reset-offsets --group test.group --topic foo --by-duration P7D         |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset to Earliest    |  --to-earliest                                |  Reset to earliest offset available: --reset-offsets --group test.group --topic foo --to-earliest                                            |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset to Latest      |  --to-latest                                  |  Reset to latest offset available: --reset-offsets --group test.group --topic foo --to-latest                                                |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset to Offset      |  --to-offset                                  |  Reset to offset 1 in all partitions: --reset-offsets --group test.group --topic foo --to-offset 1                                           |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Shift Offset by 'n'  |  --shift-by n                                 |  Reset to current offset plus 5 positions: --reset-offsets --group test.group –topic foo --shift-by 5                                        |
:----------------------+-----------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------:
| Reset from File      |  --from-file PATH_TO_FILE                     |  Reset using a file with reset plan: --reset-offsets --group test.group --from-file reset-plan.csv                                           |
'----------------------'-----------------------------------------------'----------------------------------------------------------------------------------------------------------------------------------------------'

您还可以定义要重置的分区,例如:

  • 将主题foo分区0的偏移重置为1

    --reset-offsets --group test.group --topic foo:0 --to-offset 1

  • 将主题foo分区0,1,2的偏移重置为最早

    --reset-offsets --group test.group --topic foo:0,1,2 --to-earliest

提醒:不要忘记--execute标志(请参阅KIP中的执行选项)。如果没有此标志,脚本将仅按范围打印出场景的结果,例如:

TOPIC                 PARTITION NEW-OFFSET NEW-LAG LOG-END-OFFSET CONSUMER-ID HOST CLIENT-ID
foo                   0         90         10      100            -           -    -

this answer的积分。 使用ascii tables

创建的表格

答案 1 :(得分:18)

您可以在zookeeper shell的帮助下完成此操作。 Kafka使用zookeeper跟踪消费者抵消。

转到kafka bin目录并调用zookeeper shell。(我的kafka版本是0.8.0)

./zookeeper-shell.sh localhost:2181

现在使用zookeeper get命令

get /consumers/consumer_group_id/offsets/topic/0

它显示类似

的内容
2043
cZxid = 0x4d
ctime = Wed Mar 18 03:56:32 EDT 2015
...

这里2043是消耗的最大偏移量。使用zookeeper set命令将其设置为所需的值

set /consumers/consumer_group_id/offsets/topic/0 10000

路径的框架如下/ consumers / consume / [consumer_group_id] / offsets / [topic] / [partition_id]。
您必须使用适当的消费者群体,主题和分区ID替换。

*此外,由于您提到它是kafka的新实例,我不确定消费者是否会创建连接和消费者群组。

答案 2 :(得分:3)

由于kafka 0.9偏移存储在主题中。要更改偏移量,请使用seek() method

public void seek(TopicPartition partition, long offset)
  

覆盖消费者在下一个poll(timeout)上使用的提取偏移量。如果多次为同一分区调用此API,则将在下一轮询()上使用最新的偏移量。请注意,如果在消费过程中任意使用此API,则可能会丢失数据,以重置提取偏移量

答案 3 :(得分:0)

如果需要更改偏移量。

kafka-consumer-groups --bootstrap-server {url} \
--topic {topic} \
--group {consumer} \
--reset-offsets --to-datetime 2020-11-11T00:00:00.000+0900 \
--execute

Unparseable Date Error when parsing UTC string through SimpleDateFormat to Date