Install Kafka with KRaft (without Zookeeper) on Mac OS X
- Install Java JDK version 11
- Download Apache Kafka from https://kafka.apache.org/downloads under ‘Binary Downloads’
- Extract the contents on your Mac
-
Generate a cluster ID and format the storage using
kafka-storage.sh
- Start Kafka using the binaries
- Setup the $PATH environment variables for easy access to the Kafka binaries
Installing Java JDK 11
To install Apache Kafka on Mac, Java 11 is the only prerequisite.- Navigate to Amazon Corretto 11 download page (the Amazon distribution of OpenJDK 11) install amazon-corretto-11-x64-macos-jdk.pkg
- Double click on the downloaded file and proceed with the installation steps.
- You have successfully installed Java JDK 11. You may delete the .pkg file.

Install Apache Kafka
Download the latest version of Apache Kafka from https://kafka.apache.org/downloads under Binary downloads.
2.13-2.8.1
.
3. Download and extract the contents (double click in the Finder) to a directory of your choice, for example ~/kafka_2.13-2.8.1
.
4. Navigate to the root of the Apache Kafka folder and open a Terminal. Or Open a Terminal and navigate to the root directory of Apache Kafka. For this example, we will assume that the Kafka download is expanded into the ~/kafka_2.13-2.8.1
directory.
Start Kafka
The first step is to generate a new ID for your cluster76BLQI7sT_ql1mBfKsOk9Q
Next, format your storage directory (replace <uuid>
by your UUID obtained above)
log.dirs
in the config/kraft/server.properties
file (by default /tmp/kraft-combined-logs
)
Now you can launch the broker itself in daemon mode by running this command.

Setup the $PATH environment variable
In order to easily access the Kafka binaries, you can edit your PATH variable by adding the following line (edit the content to your system) to your system run commands (for example~/.zshrc
if you use zshrc):
PATH="$PATH:/Users/stephanemaarek/kafka_2.13-2.8.1/bin"
This ensures that you can now run the kafka commands without prefixing them.
After reloading your terminal, the following should work from any directory