kafka-python consumer start reading from offset (automatically)

后端 未结 2 1957
被撕碎了的回忆
被撕碎了的回忆 2021-02-06 12:14

I\'m trying to build an application with kafka-python where a consumer reads data from a range of topics. It is extremely important that the consumer never reads the same messag

2条回答
  •  遥遥无期
    2021-02-06 12:36

    You are getting this behavior because your consumer is not using a Consumer Group. With a Consumer Group, the consumer will regularly commit (save) its position to Kafka. That way if it's restarted it will pick up from its last committed position.

    To make your consumer use a Consumer Group, you need to set group_id when constructing it. See group_id description from the docs:

    The name of the consumer group to join for dynamic partition assignment (if enabled), and to use for fetching and committing offsets. If None, auto-partition assignment (via group coordinator) and offset commits are disabled. Default: None

    For example:

    consumer = KafkaConsumer('numtest', bootstrap_servers=['localhost:9092'],
                             auto_offset_reset='earliest', enable_auto_commit=True,
                             auto_commit_interval_ms=1000, group_id='my-group')
    

提交回复
热议问题