Click here to Skip to main content
15,886,791 members
Articles / Web Development / Apache

Running Apache Kafka on Windows without Cygwin

Rate me:
Please Sign up or sign in to vote.
2.87/5 (8 votes)
10 Jan 2016CPOL5 min read 114.6K   8   23
It will give information about Installing and Configuring Apache Kafka & Zookeeper for Windows Operating System

Introduction

This tutorial aims to provide a step by step guide to run Apache Kafka on a windows OS. This guide will also provide instructions to setup Java & zookeeper. Apache kafka is a fast & scalable messaging queue, capable of handeling real heavy loads in context of read & write. You can find more about kafka on http://kafka.apache.org/. Apache kafka requires a zookeeper instance running which is used for reliable distributed cordination. Please find more about Zookeeper on https://zookeeper.apache.org/.

Check this video for Kafka setup on windows.

Downloading the Required Files

  1. Download Server JRE according to your OS & CPU architecture from http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-2133155.html
  2. Download and install 7-zip from http://www.7-zip.org/download.html
  3. Download & extract Zookeeper using 7-zip from http://zookeeper.apache.org/releases.html
  4. Download & extract Kafka using 7-zip from http://kafka.apache.org/downloads.html

Installation

a. Install & Setup Java Runtime Environment (JRE)

  1. Start JRE installation and hit the check box “Change destination folder”, then click install.

Image 1

  1. Change the installation directory to any path without spaces in folder name. Ex C:\Java\jre1.8.0_xx\. (By default it will be C:\Program Files\Java\jre1.8.0_xx) then click Next.
  2. Now open system environment variables dialogue by opening Control Panel -> System -> Advanced system settings -> Environment Variables…
  3. Hit New… button in User variables section then type JAVA_HOME in Variable name & give your jre path in Variable value. It should look like:

Image 2

(Java path and version may change according to the version of Kafka you are using)

  1. Now click ok.
  2. Search for Path variable in the “System Variable” section in “Environment Variables” dialogue box you just opened.
  3. Edit the path and type “;%JAVA_HOME%\bin” at the end of the text already written there just like image below

Image 3

  1. To confirm java installation just open cmd and type “java –version”, you should be able to see version of the java you just installed.

Image 4

If your command prompt some what looks like the image above, you are good to go. Else you need to recheck whether your setup version is matching with OS architecture (x86, x64) or environment variables path is correct in or not.

b. Installing & Running Zookeeper

  1. Goto your zookeeper config directory. For me its C:\zookeeper-3.4.7\conf
  2. Rename file “zoo_sample.cfg” to “zoo.cfg”
  3. Open zoo.cfg in any text editor like notepad but I’ll prefer notepad++.
  4. Find & edit dataDir=/tmp/zookeeper to dataDir=C:\zookeeper-3.4.7\data
  5. Add entry in System Environment Variables as we did for java
    1. Add in System Variables ZOOKEEPER_HOME = C:\zookeeper-3.4.7
    2. Edit System Variable named “Path” add ;%ZOOKEEPER_HOME%\bin;
  6. You can change the default zookeeper port in zoo.cfg file (Default port 2181).
  7. Run zookeeper by opening a new cmd & type zkserver.
  8. You will see the command prompt with some details like image below.

Image 5

Congratulations your zookeeper is up & running on port 2181.

c. Setting Up Kafka

  1. Go to your Kafka config directory. For me its C:\kafka_2.11-0.9.0.0\config
  2. Edit file “server.properties”
  3. Find & edit line “log.dirs=/tmp/kafka-logs” to “log.dir= C:\kafka_2.11-0.9.0.0\kafka-logs”.
  4. If your zookeeper is running on some other machine or cluster you can edit “zookeeper.connect=localhost:2181” to your custom IP & port. For this demo we are using same machine so no need to change. Also Kafka port & broker.id are configurable in this file. Leave other settings as it is.
  5. Your Kafka will run on default port 9092 & connect to zookeeper’s default port which is 2181.

d. Running Kafka Server

Note:

Please ensure that your zookeeper is up & running before starting Kafka server.

  1. Go to your kafka installation directory C:\kafka_2.11-0.9.0.0\
  2. Open a command prompt here by pressing Shift + right click and choose “Open command window here” option)
  3. Now type .\bin\windows\kafka-server-start.bat .\config\server.properties & press enter.

Image 6

  1. If everything went fine your command prompt will look like this one

Image 7Image 8

  1. Now your Kafka is up & running, so now you can create topics & produce or consume data from java/scala code & command prompt also.

e. Creating Kafka Topic

  1. Now create a topic with name “test” & replication factor 1 as we have only one Kafka server running. If you have a cluster with more than 1 Kafka servers running, you can increase the replication-factor accordingly which will increase the data availability & act like a fault-tolerant system.
  2. Open a new command prompt in the location C:\kafka_2.11-0.9.0.0\bin\windows
  3. Type following command and hit enter

kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test

Image 9

f. Creating a producer & consumer to test server

 

  1. Open a new command prompt in the location C:\kafka_2.11-0.9.0.0\bin\windows
  2. To start a producer type command “kafka-console-producer.bat --broker-list localhost:9092 --topic test”.
  3. Again open a new command prompt in the same location as C:\kafka_2.11-0.9.0.0\bin\windows
  4. Now start a consumer by typing command “kafka-console-consumer.bat --zookeeper localhost:2181 --topic test”.
  5. Now you will have two command prompts like image below

Image 10

  1. Now type anything in the producer command prompt & press enter and you should be able to see the message in the other consumer command prompt.

Image 11

  1. If you are able to push & see your messages in consumer side, you are done with Kafka setup.

Some Other Useful Commands

  1. List Topics: kafka-topics.bat --list --zookeeper localhost:2181
  2. Describe Topic: kafka-topics.bat --describe --zookeeper localhost:2181 --topic [Topic Name]
  3. Read messages from beginning: kafka-console-consumer.bat --zookeeper localhost:2181 --topic [Topic Name] --from-beginning
  4. Delete Topic: kafka-run-class.bat kafka.admin.TopicCommand --delete --topic [topic_to_delete] --zookeeper localhost:2181

Reference Links

  1. http://kafka.apache.org/documentation.html
  2. https://zookeeper.apache.org/doc/trunk/zookeeperStarted.html

Conclusion

I am sure, this article will be helpful for Beginners & Intermediary Programmers to Start a kafka Server on their Windows Servers or Desktops.

Yours Friendly

Gopal Tiwari

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



Comments and Discussions

 
QuestionGreat article ... Pin
Member 164523611-Dec-17 1:20
Member 164523611-Dec-17 1:20 
QuestionFATAL Shutdown broker because all log dirs Pin
Vivekananda Kuragayala18-Nov-17 10:22
Vivekananda Kuragayala18-Nov-17 10:22 
QuestionDelete Topics Pin
Adra@SRM5-Mar-17 23:25
Adra@SRM5-Mar-17 23:25 
QuestionError Broker-list Pin
NecroJohnson7-Sep-16 20:26
NecroJohnson7-Sep-16 20:26 
QuestionI just made use of this Pin
Sacha Barber15-Mar-16 23:32
Sacha Barber15-Mar-16 23:32 
Questionhi Pin
Member 1154747523-Feb-16 23:43
Member 1154747523-Feb-16 23:43 
AnswerRe: hi Pin
GopalTiwari24-Feb-16 22:50
professionalGopalTiwari24-Feb-16 22:50 
GeneralRe: hi Pin
Member 1154747525-Feb-16 3:07
Member 1154747525-Feb-16 3:07 
GeneralRe: hi Pin
GopalTiwari25-Feb-16 5:30
professionalGopalTiwari25-Feb-16 5:30 
GeneralRe: hi Pin
Member 1154747526-Feb-16 9:49
Member 1154747526-Feb-16 9:49 
GeneralRe: hi Pin
Member 1154747526-Feb-16 11:58
Member 1154747526-Feb-16 11:58 
GeneralMessage Closed Pin
27-Feb-16 9:05
professionalGopalTiwari27-Feb-16 9:05 
GeneralRe: hi Pin
Member 1154747528-Feb-16 0:58
Member 1154747528-Feb-16 0:58 
GeneralRe: hi Pin
GopalTiwari28-Feb-16 1:08
professionalGopalTiwari28-Feb-16 1:08 
GeneralRe: hi Pin
Member 115474752-Mar-16 9:35
Member 115474752-Mar-16 9:35 
GeneralRe: hi Pin
Member 1154747514-Mar-16 14:03
Member 1154747514-Mar-16 14:03 
QuestionJava edition? Pin
Member 1233204817-Feb-16 11:02
Member 1233204817-Feb-16 11:02 
Questionkafka-python on Windows? Pin
Member 1233204816-Feb-16 14:09
Member 1233204816-Feb-16 14:09 
QuestionThis is great Pin
Sacha Barber11-Feb-16 20:01
Sacha Barber11-Feb-16 20:01 
AnswerRe: This is great Pin
GopalTiwari27-Feb-16 7:07
professionalGopalTiwari27-Feb-16 7:07 
Questionkafka in windows Pin
bnagarajan13-Jan-16 0:50
bnagarajan13-Jan-16 0:50 
AnswerRe: kafka in windows Pin
GopalTiwari27-Feb-16 7:11
professionalGopalTiwari27-Feb-16 7:11 
GeneralUber for cleaning Pin
Member 1225712711-Jan-16 2:56
Member 1225712711-Jan-16 2:56 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.