在Debian上部署Kafka集群需要以下幾個步驟:
首先,確保你的Debian系統上已經安裝了Java 8或更高版本和ZooKeeper。
sudo apt update
sudo apt install openjdk-8-jdk
驗證Java安裝:
java -version
可以從Apache官網下載最新版本的ZooKeeper,然后解壓到指定目錄。
wget https://downloads.apache.org/zookeeper/zookeeper-3.8.0/apache-zookeeper-3.8.0-bin.tar.gz
tar -xzf apache-zookeeper-3.8.0-bin.tar.gz
sudo mv apache-zookeeper-3.8.0 /opt/zookeeper
配置ZooKeeper:
編輯/opt/zookeeper/conf/zoo.cfg文件,添加或修改以下配置:
server.1:2888:3888
server.2:2888:3888
server.3:2888:3888
dataDir=/opt/zookeeper/data
dataLogDir=/opt/zookeeper/log
clientPort=2181
在每個ZooKeeper節點上啟動ZooKeeper:
/opt/zookeeper/bin/zkServer.sh start
從Apache官網下載最新版本的Kafka,然后解壓到指定目錄。
wget https://downloads.apache.org/kafka/3.5.2/kafka_2.12-3.5.2.tgz
tar -xzf kafka_2.12-3.5.2.tgz
sudo mv kafka_2.12-3.5.2 /opt/kafka
在Kafka的配置目錄下,編輯server.properties文件,設置以下參數:
broker.id=1 # 每個broker的唯一標識
listeners=PLAINTEXT://your_server_ip:9092
log.dirs=/opt/kafka/logs
zookeeper.connect=localhost:2181
在每個Kafka broker上啟動Kafka:
/opt/kafka/bin/kafka-server-start.sh /opt/kafka/config/server.properties
創建一個新的主題并驗證其配置:
/opt/kafka/bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 3 --partitions 3 --topic test
/opt/kafka/bin/kafka-topics.sh --describe --zookeeper localhost:2181 --topic test
使用kafka-console-producer.sh和kafka-console-consumer.sh命令測試消息的生產和消費:
/opt/kafka/bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test
/opt/kafka/bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning
可以使用Kafka自帶的命令行工具進行基本的集群管理,也可以使用第三方監控工具如Prometheus和Grafana進行更高級的監控和管理。