It’s a digital age. Wherever there is data, we hear about Kafka these days. One of my projects I work, involves entire data system (Java backend) that leverages Kafka to achieve what deals with tonnes of data through various channels and departments. While working on it, I thought of exploring the setup in Windows. Thus, this guide helps learn Kafka and showcases the setup and test of data pipeline in Windows.
Introduction
Apache Kafka
is a distributed streaming platform with three key capabilities:
- Messaging system – Publish-Subscribe to stream of records
- Availability & Reliability – Store streams of records in a fault tolerant durable way
- Scalable & Real time – Process streams of records as they occur
Data system components
Kafka is generally used to stream data into applications, data lakes and real-time stream analytics systems.
Application inputs messages onto the Kafka server. These messages can be any defined information planned to capture. It is passed across in a reliable (due to distributed Kafka architecture) way to another application or service to process or re-process them.
Internally, Kafka uses a data structure to manage its messages. These messages have a retention policy applied at a unit level of this data structure. Retention is configurable – time based or size based. By default, the data sent is stored for 168 hours (7 days).
Kafka Architecture
Typically, there would be multiples of producers, consumers, clusters working with messages across. Horizontal scaling can be easily done by adding more brokers. Diagram below depicts the sample architecture:
Kafka communicates between the clients and servers with TCP
protocol. For more details, refer: Kafka Protocol Guide
Kafka ecosystem provides REST proxy that allows an easy integration via HTTP and JSON too.
Primarily it has four key APIs: Producer API, Consumer API, Streams API, Connector API
Key Components & related terminology
Messages
/Records – byte arrays of an object. Consists of a key, value & timestampTopic
– feeds of messages in categoriesProducer
– processes that publish messages to a Kafka topicConsumer
– processes that subscribe to topics and process the feed of published messagesBroker
– It hosts topics. Also referred as KafkaServer
or KafkaNode
Cluster
– comprises one or more brokersZookeeper
– keeps the state of the cluster (brokers, topics, consumers)Connector
– connect topics to existing applications or data systemsStream Processor
– consumes an input stream from a topic and produces an output stream to an output topicISR
(In-Sync Replica) – replication to support failover.Controller
– broker in a cluster responsible for maintaining the leader/follower relationship for all the partitions
Zookeeper
Apache ZooKeeper is an open source that helps build distributed applications. It’s a centralized service for maintaining configuration information. It holds responsibilities like:
Broker
state – maintains list of active brokers and which cluster they are part ofTopics
configured – maintains list of all topics, number of partitions for each topic, location of all replicas, who is the preferred leader, list of ISR for partitionsController
election – selects a new controller whenever a node shuts down. Also, makes sure that there is only one controller at any given timeACL
info – maintains Access control lists (ACLs) for all the topics
Kafka Internals
Brokers
in a cluster are differentiated based on an ID
which typically are unique numbers. Connecting to one broker bootstraps a client to the entire Kafka cluster. They receive messages from producers and allow consumers to fetch messages by topic, partition and offset.
A Topic
is spread across a Kafka cluster as a logical group of one or more partitions. A partition is defined as an ordered sequence of messages that are distributed across multiple brokers. The number of partitions per topic are configurable during creation.
Producers
write to Topics. Consumers
read from Topics.
Kafka uses Log
data structure to manage its messages. Log data structure is an ordered set of Segments
that are collection of messages. Each segment has files that help locate a message:
- Log file – stores message
- Index file – stores message offset and its starting position in the log file
Kafka appends records from a producer to the end of a topic log. Consumers can read from any committed offset and are allowed to read from any offset point they choose. The record is considered committed only when all ISRs for partition write to their log.
Among the multiple partitions, there is one leader and remaining are replicas/followers to serve as back up. If a leader fails, an ISR
is chosen as a new leader. Leader performs all reads and writes to a particular topic partition. Followers passively replicate the leader. Consumers are allowed to read only from the leader partition.
A leader and follower of a partition can never reside on the same node.
Kafka also supports log compaction
for records. With it, Kafka will keep the latest version of a record and delete the older versions. This leads to a granular retention mechanism where the last update for each key is kept.
Offset manager
is responsible for storing, fetching and maintaining consumer offsets. Every live broker has one instance of an offset manager. By default, consumer is configured to use an automatic commit policy of periodic interval. Alternatively, consumer can use a commit API for manual offset management.
Kafka uses a particular topic, __consumer_offsets
, to save consumer offsets. This offset records the read location of each consumer in each group. This helps a consumer to trace back its last location in case of need. With committing offsets to the broker, consumer no longer depends on ZooKeeper.
Older versions of Kafka (pre 0.9) stored offsets in ZooKeeper only, while newer version of Kafka, by default stores offsets in an internal Kafka topic __consumer_offsets
Kafka allows consumer groups
to read data in parallel from a topic. All the consumers in a group has same group ID. At a time, only one consumer from a group can consume messages from a partition to guarantee the order of reading messages from a partition. A consumer can read from more than one partition.
Kafka Setup On Windows
Pre-Requisite
- Java SE Runtime Environment
- System has: jre-8u261-windows-x64.exe
- Kafka
- Sample app uses: Scala 2.12 – kafka_2.12-2.5.0.tgz
- Any unzip tool to extract files out of *.tgz
- I have Mac that extracted it just by double click
Setup files
- Install JRE – default settings should be fine
- Un-tar Kafka files at C:\Installs (could be any location by choice). All the required script files for Kafka data pipeline setup will be located at: C:\Installs\kafka_2.12-2.5.0\bin\windows
- Configuration changes as per Windows need
- Setup for Kafka logs – Create a folder ‘logs’ at location C:\Installs\kafka_2.12-2.5.0
- Set this logs folder location in Kafka config file: C:\Installs\kafka_2.12-2.5.0\config\server.properties as log.dirs=C:\Installs\kafka_2.12-2.5.0\logs
- Setup for Zookeeper data – Create a folder ‘data’ at location C:\Installs\kafka_2.12-2.5.0
- Set this data folder location in Zookeeper config file: C:\Installs\kafka_2.12-2.5.0\config\zookeeper.properties as dataDir=C:\Installs\kafka_2.12-2.5.0\data
Execute
ZooKeeper
– Get a quick-and-dirty single-node ZooKeeper instance using the convenience script already packaged along with Kafka files.- Open a command prompt and move to location: C:\Installs\kafka_2.12-2.5.0\bin\windows
- Execute script:
zookeeper-server-start.bat C:\Installs\kafka_2.12-2.5.0\config\zookeeper.properties
- ZooKeeper started at localhost:2181. Keep it running.
Kafka Server
– Get a single-node Kafka instance.- Open another command prompt and move to location: C:\Installs\kafka_2.12-2.5.0\bin\windows
- ZooKeeper is already configured in the properties file as zookeeper.connect=localhost:2181
- Execute script:
kafka-server-start.bat C:\Installs\kafka_2.12-2.5.0\config\server.properties
- Kafka server started at localhost: 9092. Keep it running. Now, topics can be created and messages can be stored. We can produce and consume data from any client. We will use command prompt for now.
Topic
– Create a topic named ‘testkafka’- Use replication factor as 1 & partitions as 1 given we have made a single instance node
- Open another command prompt and move to location: C:\Installs\kafka_2.12-2.5.0\bin\windows
- Execute script:
kafka-topics.bat --create --bootstrap-server localhost:9092 --replication-factor 1 --partitions 1 --topic testkafka
- Execute script to see created topic:
kafka-topics.bat --list --bootstrap-server localhost:9092
- Keep the command prompt open just in case.
Producer
– setup to send messages to the server- Open another command prompt and move to location: C:\Installs\kafka_2.12-2.5.0\bin\windows
- Execute script:
kafka-console-producer.bat --bootstrap-server localhost:9092 --topic testkafka
- It will show a ‘>’ as a prompt to type a message. Type: “Kafka demo – Message from server”
- Keep the command prompt open. We will come back to it to push more messages
Consumer
– setup to receive messages from the server- Open another command prompt and move to location: C:\Installs\kafka_2.12-2.5.0\bin\windows
- Execute script:
kafka-console-consumer.bat --bootstrap-server localhost:9092 --topic testkafka --from-beginning
- You would see the Producer sent message in this command prompt window – “Kafka demo – Message from server”
- Go back to Producer command prompt and type any other message to see them appearing real time in Consumer command prompt
Check/Observe
– few key changes behind the scene- Files under topic created – they keep track of the messages pushed for a given topic
- Data inside the log file – All the messages that are pushed by producer are stored here
- Topics present in Kafka – once a consumer starts reading messages from topic,
__consumer_offsets
is automatically created as a topic
NOTE: In case you want to choose Zookeeper to store topics instead of Kafka server, it would require following script commands:
- Topic create:
kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic testkafka
- Topics view:
kafka-topics.bat --list --zookeeper localhost:2181
With above, we are able to see messages sent by Producer and received by Consumer using a Kafka setup.
When I tried to setup Kafka, I faced few issues on the way. I have documented them for reference to learn. This should also help others if they face something similar: Troubleshoot: Kafka setup on Windows.
One should not encounter any issues with below shared files and the steps/commands shared above.
Download entire modified setup files for Windows from here: https://github.com/sandeep-mewara/kafka-demo-windows
References:
https://kafka.apache.org
https://cwiki.apache.org/confluence/display/KAFKA
https://docs.confluent.io/2.0.0/clients/consumer.html