【发布时间】:2016-06-14 21:27:51
【问题描述】:
我在我的 node.js 服务器上使用kafka-node - 用于连接到 kafka 主题。在他们的 API 中有一个回调函数:
consumer.on('message', function (message) {
console.log(message);
});
用于在消息到达时使用它们。
我想知道是否以及如何向此回调函数添加参数,因为我不是在消息到达时调用它的人。
更具体地说,我想发送预期的 ID 并将其与消费的消息 ID 进行比较:
consumer.on('message', function (message, id) {
if (id == message.id)
console.log(message);
});
编辑: 这是一个更大代码的 sn-p。 完整的流程是:
- 用户向 node.js 服务器请求 http 请求。
- GET HTTP 请求在 node.js 服务器中被触发。
- kafka 生产者向外部系统发送一些消息(具有唯一 ID)并等待响应。
- 收到对 kafka 消费者的响应。接收到的消息 id 与预期的 id 进行比较 - 如果相等 - 将消息作为 http 响应返回。
考虑可以并行接收多个http get请求。
【问题讨论】:
-
让我们假设,事件传递了名为 id 的第二个参数,但
id == message.id将始终为true。那么你到底期待什么? -
@Oxi 我已将帖子编辑得更准确。
标签: javascript node.js apache-kafka kafka-consumer-api