Step-by-step guide: Installing Kafka from scratch on Linux
1. Preparation
Before starting the installation, you need to ensure that your system meets the following requirements:
- Operating system: Ubuntu 16.04 or higher
- Memory: At least 4GB
- Hard disk space: At least 500GB
- Java: Version 8 or higher
- ZooKeeper: Version 3.4 or higher
2. Install Java
- Use the following command to update the system package list:
sudo apt-get update
- Install Java:
sudo apt-get install openjdk-8-jdk
- Verify whether Java has been successfully installed:
java -version
3. Install ZooKeeper
- Download ZooKeeper:
wget https://mirrors.estointernet.in/apache/zookeeper/zookeeper-3.6.3/zookeeper-3.6.3.tar.gz
- Unzip ZooKeeper:
tar -xzvf zookeeper-3.6.3.tar.gz
- Move ZooKeeper to the installation directory:
sudo mv zookeeper-3.6.3 /opt/zookeeper
- Create ZooKeeper users and groups:
sudo groupadd zookeeper sudo useradd -g zookeeper zookeeper
- Grant permissions to the ZooKeeper user and group on the installation directory:
sudo chown -R zookeeper:zookeeper /opt/zookeeper
- Edit the ZooKeeper configuration file:
sudo nano /opt/zookeeper/conf/zoo.cfg
- In the configuration file , change the values of the
dataDir
andclientPort
options to/var/lib/zookeeper
and2181
respectively:
dataDir=/var/lib/zookeeper clientPort=2181
- Create ZooKeeper data directory:
sudo mkdir -p /var/lib/zookeeper sudo chown -R zookeeper:zookeeper /var/lib/zookeeper
- Start ZooKeeper:
sudo /opt/zookeeper/bin/zkServer.sh start
- Verify that ZooKeeper has started successfully:
sudo netstat -plnt | grep 2181
4. Install Kafka
- Download Kafka:
wget https://mirrors.estointernet.in/apache/kafka/2.8.1/kafka_2.13-2.8.1.tgz
- Unzip Kafka:
tar -xzvf kafka_2.13-2.8.1.tgz
- Move Kafka to the installation directory:
sudo mv kafka_2.13-2.8.1 /opt/kafka
- Create Kafka user and group:
sudo groupadd kafka sudo useradd -g kafka kafka
- Grant Kafka user and group to the installation directory Permissions:
sudo chown -R kafka:kafka /opt/kafka
- Edit Kafka configuration file:
sudo nano /opt/kafka/config/server.properties
- In the configuration file, change the values of the following options to:
broker.id=0 listeners=PLAINTEXT://:9092 zookeeper.connect=localhost:2181
- Create Kafka data directory:
sudo mkdir -p /var/lib/kafka sudo chown -R kafka:kafka /var/lib/kafka
- Start Kafka:
sudo /opt/kafka/bin/kafka-server-start.sh /opt/kafka/config/server.properties
- Verify whether Kafka has been started successfully :
sudo netstat -plnt | grep 9092
5. Test Kafka
- Create a topic:
kafka-topics --create --topic test --partitions 1 --replication-factor 1
- Send a message to the topic:
kafka-console-producer --topic test --message "Hello, world!"
- Receive messages from the topic:
kafka-console-consumer --topic test --from-beginning
6. Summary
You have successfully installed Kafka under Linux. Now, you can start building distributed systems using Kafka.
The above is the detailed content of Step-by-step guide: Installing Kafka from scratch on Linux. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Using python in Linux terminal...

Configure the apscheduler timing task as a service on macOS platform, if you want to configure the apscheduler timing task as a service, similar to ngin...

Multithreading in the language can greatly improve program efficiency. There are four main ways to implement multithreading in C language: Create independent processes: Create multiple independently running processes, each process has its own memory space. Pseudo-multithreading: Create multiple execution streams in a process that share the same memory space and execute alternately. Multi-threaded library: Use multi-threaded libraries such as pthreads to create and manage threads, providing rich thread operation functions. Coroutine: A lightweight multi-threaded implementation that divides tasks into small subtasks and executes them in turn.

To open a web.xml file, you can use the following methods: Use a text editor (such as Notepad or TextEdit) to edit commands using an integrated development environment (such as Eclipse or NetBeans) (Windows: notepad web.xml; Mac/Linux: open -a TextEdit web.xml)

Regarding the problem of removing the Python interpreter that comes with Linux systems, many Linux distributions will preinstall the Python interpreter when installed, and it does not use the package manager...

Linux is best used as server management, embedded systems and desktop environments. 1) In server management, Linux is used to host websites, databases, and applications, providing stability and reliability. 2) In embedded systems, Linux is widely used in smart home and automotive electronic systems because of its flexibility and stability. 3) In the desktop environment, Linux provides rich applications and efficient performance.

DebianLinux is known for its stability and security and is widely used in server, development and desktop environments. While there is currently a lack of official instructions on direct compatibility with Debian and Hadoop, this article will guide you on how to deploy Hadoop on your Debian system. Debian system requirements: Before starting Hadoop configuration, please make sure that your Debian system meets the minimum operating requirements of Hadoop, which includes installing the necessary Java Runtime Environment (JRE) and Hadoop packages. Hadoop deployment steps: Download and unzip Hadoop: Download the Hadoop version you need from the official ApacheHadoop website and solve it

"DebianStrings" is not a standard term, and its specific meaning is still unclear. This article cannot directly comment on its browser compatibility. However, if "DebianStrings" refers to a web application running on a Debian system, its browser compatibility depends on the technical architecture of the application itself. Most modern web applications are committed to cross-browser compatibility. This relies on following web standards and using well-compatible front-end technologies (such as HTML, CSS, JavaScript) and back-end technologies (such as PHP, Python, Node.js, etc.). To ensure that the application is compatible with multiple browsers, developers often need to conduct cross-browser testing and use responsiveness
