Consume Messages Using REST API
If you do not have a Kafka cluster and/or topic already, follow these steps to create one.
In the cluster details section of the
Upstash Console, scroll down the REST API
section and and copy UPSTASH_KAFKA_REST_URL
, UPSTASH_KAFKA_REST_USERNAME
and
UPSTASH_KAFKA_REST_PASSWORD
using the copy icons next to them.
We will use a Node.js
sample code to show how to consume messages using the
REST API. Our sample will use a topic named cities
and consume previously
produced city names from this topic using Kafka consumer groups and automatic
offset committing.
Replace following parameters in the code snippets below with your actual values.
Following code will consume city names using mygroup
consumer group id and
myconsumer
consumer id from the topic starting from the latest offset and
print the consumed messages and their offsets to the console:
By default consume API starts consuming from the latest offset. It’s also
possible to start from the earliest offset by passing
Kafka-Auto-Offset-Reset: earliest
request header:
We can also go deeper and turn off auto-commit behaviour of the consumer to
manually commit the offsets later. To turn off auto commit, we should send
Kafka-Enable-Auto-Commit: false
header. This allows us to commit the offsets
only when all messages processed successfully.
For more info about using the REST API see Kafka REST Consume API section.