在使用消费者组使用Kafka消息时,我收到重复的消息。
我正在使用此Nodejs库。 https://www.npmjs.com/package/kafka-node
下面提供了我的消费者代码
const config = require( '../../configs' );
const kafka = require( 'kafka-node' );
var options = {
id: 'consumer1',
kafkaHost: config.kafka.prod.kafka_host, //multiple kafka hosts (comma separated)
groupId: "test-group2",
sessionTimeout: 15000,
protocol: ['roundrobin'],
fromOffset: 'earliest'
};
var consumerGroup = new kafka.ConsumerGroup( options, 'my-replicated-topic3' );
consumerGroup.on( 'message', function ( message ) {
console.log( message );
} );
我的成绩低于预期。
{ topic: 'my-replicated-topic3',
value: '{"meta":{"topic":"my-replicated-topic3","added_at":"2019-02-22T09:25:54.708Z","server":"cron"},"data":"1550827554708 ::: Totam quis qui. Sit dolore laboriosam odio. Facilis porro et quam repellat pariatur. Ad voluptatem quidem."}',
offset: 8941,
partition: 0,
highWaterOffset: 8966,
key: null }
---
---
---
---
{ topic: 'my-replicated-topic3',
value: '{"meta":{"topic":"my-replicated-topic3","added_at":"2019-02-22T09:25:54.708Z","server":"cron"},"data":"1550827554708 ::: Totam quis qui. Sit dolore laboriosam odio. Facilis porro et quam repellat pariatur. Ad voluptatem quidem."}',
offset: 8941,
partition: 0,
highWaterOffset: 8970,
key: null }
您可以看到每隔几条记录后便会重复相同的消息。消息的偏移量相同,但所有重复的消息 highWaterOffset 不同。
请提出解决方法。
答案 0 :(得分:0)
您是否重新实例化您的消费者?您的消费者如何承担补偿?
默认情况下,您的使用者每5秒自动提交一次偏移。您的图书馆就是这种情况。
如果您在提交偏移量之前重新实例化了使用者,它将从上次提交的偏移量重新启动。