node-rdkafka-promise
v0.0.3
Published
The high-level node kafka client with Promise support .
Downloads
20
Readme
Node Rdkafka Promise
The high-level node kafka client with Promise support .
Usage
Install
npm i node-rdkafka-promise -S
Kafka Producer
const producer = new KafkaProducer({
'client.id': 'kafka',
'metadata.broker.list': 'localhost:9092',
'compression.codec': 'gzip',
'retry.backoff.ms': 200,
'message.send.max.retries': 10,
'socket.keepalive.enable': true,
'queue.buffering.max.messages': 100000,
'queue.buffering.max.ms': 1000,
'batch.num.messages': 1000000,
'dr_cb': true
}, {})
producer.connect()
.then(() => {
producer.produce('topicName', -1, 'some message')
.catch(err => {
console.error(err)
})
})
.catch(err => {
console.error(err)
})
Kafka Consumer
const consumer = new KafkaConsumer({
'group.id': 'kafka',
'metadata.broker.list': 'localhost:9092',
})
consumer.connect()
.then(async () => {
// fetch mode : get one message
const message = await consumer.fetch()
// flowing mode : registed callback function , it will be executed once get the new message
consumer.flowing((err, message) => {
if (err) {
console.error(err)
return
}
console.log(message)
})
})