node-rdkafka-promise
TypeScript icon, indicating that this package has built-in type declarations

0.0.3 • Public • Published

Node Rdkafka Promise

npm npm

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)
    })
  })

Readme

Keywords

none

Package Sidebar

Install

npm i node-rdkafka-promise

Weekly Downloads

16

Version

0.0.3

License

MIT License

Unpacked Size

15.1 kB

Total Files

16

Last publish

Collaborators

  • joway