Node-RED (http://nodered.org) nodes for publish/subscribe messaging using the new Apache Kafka Consumer/Producer API and without requiring direct communications with Zookeeper. Based on the the high performance librdkafka Apache Kafka C/C++ library (https://github.com/edenhill/librdkafka).
This module is a fork of Hans Jespersen's node-red-contrib-rdkafka module, with only minor additions to enable making secured authenticated connections to Kafka brokers.
- Up to date support for Apache Kafka 0.9, 0.10, and 0.11 including Confluent version 2.x and 3.x
- High performance through use of librdkafka C/C++ library (see https://github.com/edenhill/librdkafka)
- Up to date feature set from use of node-rdkafka node.js client (see https://github.com/Blizzard/node-rdkafka)
- Tested on Linux, macOS, and Raspberry Pi / Raspbian Jessie
- Supports dynamic topic selection via incoming msg.topic value
- Supports dynamic partition selection via incoming msg.partition value
- Supports event time timestamps (with Kafka 0.10+) via msg/timestamp value
- Uses
auto.offset.commit
to commit consumers offsets - Supports providing credentials and/or certificates for making secured connections
Run the following command in the root directory of your Node-RED install (typically ~/.node-red)
npm install node-red-contrib-rdkafka-secure
You may see a lot of warnings as librdkafka compiles and installs, particularily on MacOS, but it does work.
If you need SSL support on MacOS, check out the node-rdkafka instructions for environment variables you will need to set before running npm install
.
Start node-red as normal or with -v
for better debugging
node-red -v
Point your browser to http://localhost:1880
You should see white rdkafka input and output nodes in the pallet on the left side of the screen.
Drag either rdkafka node to the canvas and double click to configure the Kafka topic, brokers, clientID and groupID.
Click on the pencil icon to the right of the broker selection box to configure a kafka broker connection if one does not already exist.
Publish and subscribe just as you would with the mqtt node with some small differences namely:
- topics should not contain "/" or "." characters
- kafka wildcard/regex subscriptions are not yet fully tested
- ensure you have unique Group IDs configured unless you want multiple consumers to be in a Kafka consumer group
Hans Jespersen, https://github.com/hjespers
For more information, feedback, or support see https://github.com/hjespers/node-red-contrib-rdkafka/issues