Skip to main content

[SOLVED] How to install Kafka on Windows? - kafka

[SOLVED] A Simple Guide to Installing Kafka on Windows

Apache Kafka is a strong messaging system. It helps us build real-time data pipelines and streaming apps. In this chapter, we will show you how to install Kafka on Windows step-by-step. This way, you will have all the tools to set up and run Kafka well. Whether we are developers trying out Kafka or system admins getting ready to use it in real work, this guide will help us through the whole installation process.

In this article, we will look at these parts to install Kafka on Windows:

  • Part 1 - Prerequisites for Kafka Installation: Learn the system needs and what software we need to install.
  • Part 2 - Downloading Kafka for Windows: Find out where to get the Kafka files and how to download them.
  • Part 3 - Setting Up Kafka Environment Variables: Set environment variables to help Kafka run smoothly.
  • Part 4 - Starting Zookeeper Server: Follow simple steps to start the Zookeeper server, which we need for Kafka.
  • Part 5 - Starting Kafka Server: Get instructions to start the Kafka server and check if it runs right.
  • Part 6 - Testing Kafka Installation: Test our Kafka installation with commands to make sure everything works well.

If we follow this guide, we can install Kafka on our Windows computer. Then we can start creating great real-time applications with this strong tool. For more tips on using Kafka in different setups, we can check how to connect to Kafka running in Docker or learn about Kafka with Google Cloud Pub/Sub.

Let’s start our journey to learn how to install Kafka on Windows!

Part 1 - Prerequisites for Kafka Installation

Before we start installing Kafka on Windows, we need to check some things. Kafka needs the Java Runtime Environment (JRE) and Apache Zookeeper. So, let’s make sure we have these installed and set up:

  1. Java Development Kit (JDK): Kafka is made with Java. We have to install the Java Development Kit (JDK) on our system. The best version to use is JDK 8 or later. We can download the latest version from Oracle’s official website or we can use a free version like OpenJDK.

    • After we install it, we can check if it worked. Open the command prompt and run this command:

      java -version
    • We should see a message that shows the version of Java we have.

  2. Apache Zookeeper: Kafka needs Zookeeper to help it work together across many machines. We can run Zookeeper inside Kafka, but it is better to install it separately. We can download Zookeeper from the Apache Zookeeper website.

  3. Environment Variables: We need to set up some environment variables for Java. We should add a variable called JAVA_HOME that points to where we installed the JDK. We also need to change the PATH variable to include the bin folder of the JDK.

    • To set environment variables in Windows:
      • Right-click on ‘This PC’ or ‘My Computer’ and choose ‘Properties’.
      • Click ‘Advanced system settings’ and then ‘Environment Variables’.
      • In ‘System variables’, click ‘New’ to make a new variable named JAVA_HOME and set it to the path of our JDK, like C:\Program Files\Java\jdk-11.0.10.
      • Find the Path variable in ‘System variables’, click ‘Edit’, and add a new entry for %JAVA_HOME%\bin.
  4. Windows Subsystem for Linux (Optional): If we like using a Unix-like system, we can install Windows Subsystem for Linux (WSL). This lets us run a Linux system on Windows. It can help us with Kafka development. We can enable WSL using PowerShell:

    wsl --install
  5. Disk Space: We should check that we have enough disk space. Kafka can create a lot of log data, especially when we use it in production. It is best to have a few gigabytes of free space.

  6. Network Configuration: We need to make sure our firewall allows traffic on the ports for Kafka and Zookeeper. By default, Zookeeper uses port 2181 and Kafka uses port 9092. We might need to change our firewall settings to allow this.

Once we have these things ready, we can download and install Kafka on Windows. For more help, we can look at the Kafka installation documentation.

Part 2 - Downloading Kafka for Windows

We need to download the Kafka binaries to install Kafka on Windows. Here are the simple steps to download Kafka for Windows:

  1. Visit the Apache Kafka Download Page: Go to the official Apache Kafka Downloads page. You will find the newest version of Kafka there.

  2. Select the Version: Pick the latest stable version of Kafka. In October 2023, the best version is Apache Kafka 3.5.0. Click the link to download the binary package.

  3. Download the Binary: Find the “Binary” download link. It usually looks like kafka_2.12-3.5.0.tgz or something similar. Click on it to start downloading. You may also see a .zip format. This is better for Windows users.

  4. Extract the Downloaded File: After the download is done, go to the place where you saved the file. If you got a .tgz file, you need a tool like 7-Zip or WinRAR to extract it. If it’s a .zip file, you can use the built-in Windows extractor.

    • Right-click on the downloaded file and choose “Extract All…”
    • Pick a folder for the files (for example, C:\kafka).
  5. Verify the Download: After extracting, go to the folder where Kafka was extracted. You should see several folders like bin, config, and libs.

  6. Download Java: Kafka needs Java to work. Make sure you have the Java Development Kit (JDK) on your computer. You can download the latest version from Oracle JDK or OpenJDK. After you install it, check if it works by running:

    java -version
  7. Set Up Kafka Directory Structure: We should keep our Kafka installation neat. Create folders for your projects, logs, and config files as you need.

After these steps, we will have downloaded Kafka for Windows. We can now move to the next steps in the installation, like setting up environment variables and starting the servers.

For more details on how to configure Kafka, you can look at our guide on Kafka installation.

Part 3 - Setting Up Kafka Environment Variables

Setting up environment variables is very important for a smooth Kafka installation on Windows. It helps us run Kafka commands from any command prompt. We do not need to type the full path to the Kafka installation each time.

Steps to Set Up Kafka Environment Variables

  1. Open System Properties:

    • Right-click on “This PC” or “Computer” on your desktop or in File Explorer.
    • Click on “Properties”.
    • Click on “Advanced system settings” on the left side.
    • In the System Properties window, click on the “Environment Variables” button.
  2. Add KAFKA_HOME Variable:

    • In the Environment Variables window, under “System variables”, click on “New”.
    • For the “Variable name”, write KAFKA_HOME.
    • For the “Variable value”, write the path to your Kafka installation directory, like C:\kafka_2.13-2.8.0 (change this path according to your Kafka installation).
    • Click “OK”.
  3. Update the PATH Variable:

    • In the same “Environment Variables” window, find the Path variable under “System variables” and select it.
    • Click on “Edit”.
    • Click on “New” and add this path (change the version if needed):
      • C:\kafka_2.13-2.8.0\bin\windows
    • This lets us run Kafka scripts directly from the command prompt.
  4. Confirm the Setup:

    • Open a new Command Prompt window (you might need to close and open it again for changes to work).

    • Type this command to check if KAFKA_HOME is set right:

      echo %KAFKA_HOME%
    • You should see the path to your Kafka installation directory.

Running Kafka Commands

Now that we set the environment variables, we can run Kafka commands from any command prompt. For example, to start Zookeeper, we can just use:

cd %KAFKA_HOME%
.\bin\windows\zookeeper-server-start.bat .\config\zookeeper.properties

This setup makes our development process easier and helps us manage our Kafka installation better. For more details on Kafka configurations, we can look at the Kafka Installation guide.

Part 4 - Starting Zookeeper Server

To run Apache Kafka on Windows, we need to start the Zookeeper server first. Zookeeper helps us manage configuration, naming, synchronization, and group services. Kafka uses Zookeeper to handle brokers and keep metadata.

Step-by-Step Guide to Starting Zookeeper

  1. Navigate to Your Kafka Directory
    Open a command prompt. Change the directory to where we installed Kafka. For example, if Kafka is in C:\kafka, we run:

    cd C:\kafka
  2. Start Zookeeper
    Kafka comes with Zookeeper. We can start it using the command line. Use this command to start Zookeeper:

    .\bin\windows\zookeeper-server-start.bat .\config\zookeeper.properties
  3. Verify Zookeeper is Running
    After we run the command, we should see log messages. These messages tell us that Zookeeper started successfully. We look for messages like:

    [myid:] starting quorum...

    This means Zookeeper is running and ready to connect.

Configuration Details

The zookeeper.properties file is in the config directory. It has settings for Zookeeper. Here are some important ones we should check:

  • tickTime: This is the basic time unit in milliseconds for Zookeeper. The default is 2000.
  • dataDir: This is where Zookeeper stores its data. We should choose a valid directory.

Example configuration in zookeeper.properties:

tickTime=2000
dataDir=C:/kafka/zookeeper-data

Stopping Zookeeper

To stop the Zookeeper server, we can close the command prompt window where it runs. Or we can run this command in another command prompt:

.\bin\windows\zookeeper-server-stop.bat

Troubleshooting Common Issues

  • Port Conflicts: We should make sure that the default port for Zookeeper (2181) is not used by another application.
  • Configuration Issues: We need to double-check our zookeeper.properties file for any wrong settings.

By starting the Zookeeper server, we can now start the Kafka server and explore all its features. For more details on Kafka’s setup and how it works with Zookeeper, we can check Kafka Cluster Architecture.

Part 5 - Starting Kafka Server

To start the Kafka server on Windows, we need to make sure that Zookeeper is running. Kafka uses Zookeeper to manage the cluster. Once Zookeeper is running, we can start the Kafka server. Let us follow these simple steps:

  1. Open a Command Prompt: We go to the folder where we extracted Kafka. This is usually the folder with kafka_2.13-<version>.

  2. Start the Kafka Server: We run this command in the command prompt:

    .\bin\windows\kafka-server-start.bat .\config\server.properties

    This command starts the Kafka server with the default settings in server.properties.

  3. Check Kafka Server Logs: As the server starts, we will see logs in the command prompt. These logs show that the process is running. We should look for messages like “Kafka server started” to confirm the server is working.

Important Configuration Settings

Before we start the Kafka server, we might want to change some settings in the server.properties file in the config folder:

  • Broker ID: Each Kafka broker needs a unique ID. We can set it in the server.properties file:

    broker.id=0
  • Listeners: We need to set where the Kafka server listens for client connections. A common setting for a local setup is:

    listeners=PLAINTEXT://localhost:9092
  • Log Directory: We set where Kafka will keep its log files:

    log.dirs=.\kafka-logs

By default, Kafka keeps logs in the kafka-logs folder under the Kafka installation folder.

Verify Kafka Server is Running

To check if our Kafka server is running, we can use this command to see the status:

.\bin\windows\kafka-topics.bat --list --bootstrap-server localhost:9092

If the server is working well, this command will show a list of topics. It may be empty at first.

Additional Resources

For more information about Kafka and its settings, we can check these resources:

By doing these steps, we can start the Kafka server on our Windows machine. Now it is ready for message production and consumption.

Part 6 - Testing Kafka Installation

To check if we installed Kafka on Windows correctly, we need to do some tests. We will create a topic, send messages, and read those messages. This part will help us test our Kafka installation step by step.

Step 1: Create a Topic

First, we create a topic for sending and receiving messages. We open a command prompt and go to the Kafka installation folder. This is where we extracted Kafka. We use this command to create a topic called test:

cd kafka_2.13-<version>\bin\windows
kafka-topics.bat --create --topic test --bootstrap-server localhost:9092 --partitions 1 --replication-factor 1

We need to replace <version> with the version number of Kafka we installed.

Step 2: Produce Messages to the Topic

Next, we will send messages to the test topic. In the same command prompt, we run this command:

kafka-console-producer.bat --topic test --bootstrap-server localhost:9092

When the producer is running, we can start typing messages. We press Enter after each message to send it to the topic. For example:

Hello Kafka
This is a test message

Step 3: Consume Messages from the Topic

Now, we open a new command prompt window to read the messages we just sent. We go to the Kafka installation folder again and use this command:

kafka-console-consumer.bat --topic test --from-beginning --bootstrap-server localhost:9092

This command will read messages from the start of the test topic. We should see the messages we sent earlier in the console:

Hello Kafka
This is a test message

Step 4: Verify Kafka Installation

If we see the messages in the consumer console, great! Our Kafka installation on Windows is working fine. We can try more by creating more topics, sending more messages, and reading them.

Troubleshooting

If we have any problems during testing, we should check:

  • Zookeeper and Kafka servers are running. We can see this in the command prompt where we started them.
  • We are using the right Kafka version in the commands.
  • Our firewall settings let traffic through the default Kafka port (9092).

For more help on connecting to Kafka or fixing common problems, we can check our guides on connecting to Kafka and Kafka installation.

Conclusion

In this guide, we learn how to install Kafka on Windows. We talk about important steps like what we need before starting, how to download Kafka, set environment variables, and start Zookeeper and Kafka servers.

If we follow these steps, we can set up Kafka for our projects. This will help us to explore what Kafka can do.

For more advanced uses, we can check out how to connect to Kafka running in different environments or how to use Kafka with Spark for real-time data processing.

Comments