一、前言
kafka是基于jdk和zk上运行的,安装kafka前必须安装jdk和zk。
二、jdk安装
2.1 下载jdk
安装文件: http://www.oracle.com/technetwork/java/javase/downloads/index.html 下载JDK
2.2 设置环境变量
2.2.1 windows环境下需要设置
安装完成后需要添加以下的环境变量(右键点击“我的电脑” -> "高级系统设置" -> "环境变量" ):
JAVA_HOME: D:\Program Files\java\jdk1.8.0_91 (jdk的安装路径)
Path: 在现有的值后面添加"; %JAVA_HOME%\bin"
2.2.2 linux环境下需要设置
编辑用户profile
vi ~/.bash_profile
增加以下设置:
export JAVA_HOME=/opt/esb/jdk1.7.0_80 (jdk的安装路径)
export JAVA_BIN=$JAVA_HOME/bin
export PATH=$JAVA_BIN:$PATH:$HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH CLASSPATH
增加完成后执行:
source ~/.bash_profile
2.3 校验
打开cmd运行 java -version
查看当前系统Java的版本:
三、zookeeper安装
Kafka 集群中有一个 broker 会被选举为 Controller,负责管理集群 broker 的上下线,所有 topic 的分区副本分配和 leader 选举等工作。Controller 的管理工作都是依赖于 Zookeeper 的。
3.1 下载zk
安装文件 http://zookeeper.apache.org/releases.html 下载zk
3.2 配置
解压安装包到目标位置,conf,把zoo_sample.cfg重命名成zoo.cfg,并打开zoo.cfg,把dataDir的值改成
dataDir=..\data
3.3 启动
进入zk文件目录,执行以下命令,
3.3.1 windows环境
bin\windows\zookeeper-server-start.bat config\zookeeper.properties
3.3.2 linux环境
./bin/zookeeper-server-start.sh -daemon config/zookeeper.properties
或者
./bin/zookeeper-server-start.sh start
四、kafka安装
4.1 下载kafka
下载路径: http://kafka.apache.org/downloads
4.2 配置
解压安装包到目标位置,打开config下server.properties文件,把log.dirs修改为:
log.dirs=logs
server.properties更多可用配置及含义如下:
1 | #broker 的全局唯一编号,不能重复 |
4.3 启动kafka
进入kafka文件目录,执行以下命令,启动kafka通讯的服务器broker
4.3.1 windows环境
bin\windows\kafka-server-start.bat .\config\server.properties
4.3.2 linux环境
./bin/kafka-server-start.sh config/server.properties
五、测试
5.1 创建消息topics
进入kafka文件目录\bin\windows,执行以下命令
kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test
这条命令的意思是,创建一个Topic到ZK(指定ZK的地址),副本个数为1,分区数为1,Topic的名称为test。
Linux对应的命令为:
./bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic test
在较新版本(2.2 及更高版本)的 Kafka 不再需要 ZooKeeper 连接字符串,即- -zookeeper localhost:2181。使用 Kafka Broker的 --bootstrap-server localhost:9092来替代- -zookeeper localhost:2181。
./bin/kafka-topics.sh --bootstrap-server localhost:9092 --create --replication-factor 1 --partitions 1 --topic test
5.2 查看topics
创建好后我们可以查看Kafka里的Topic列表:
bin\windows\kafka-topics.bat --list --zookeeper localhost:2181
Linux对应的命令为:
./bin/kafka-topics.sh --list --zookeeper localhost:2181
2.2及更高版本
./bin/kafka-topics.sh --list --bootstrap-server localhost:9092
查看test Topic的具体信息:
bin\windows\kafka-topics.bat --describe --zookeeper localhost:2181 --topic test
Linux对应的命令为:
./bin/kafka-topics.sh --describe --zookeeper localhost:2181 --topic test
2.2及更高版本
./bin/kafka-topics.sh --describe --bootstrap-server localhost:9092 --topic test
5.2 创建Producer
分别打开cmd窗口,进入kafka文件目录\bin\windows,执行下面命令
kafka-console-producer.bat --broker-list localhost:9092 --topic test
Linux下对应的命令为:
kafka-console-producer.sh --broker-list localhost:9092 --topic test
5.3 创建Consumer
分别打开cmd窗口,进入kafka文件目录\bin\windows,执行下面命令
kafka-console-consumer.bat --bootstrap-server localhost:9092 --topic test
Linux下对应的命令为:
./bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test
5.4 发送消息测试
六、常用命令
6.1 查看当前服务器中的所有 topic
./bin/kafka-topics.sh --list --zookeeper localhsot:2181
2.2及更高版本
./bin/kafka-topics.sh --list --bootstrap-server localhost:9092
windows对应的命令为:
kafka-topics.bat --list --zookeeper localhost:2181
6.2 删除 topic
./bin/kafka-topics.sh --zookeeper localhost:2181 --delete --topic test
2.2及更高版本
./bin/kafka-topics.sh --bootstrap-server localhost:9092 --delete --topic test
windows对应的命令为:
kafka-topics.bat --zookeeper localhost:2181 --delete --topic test
注意
:需要 server.properties 中设置delete.topic.enable=true否则只是标记删除。
6.3 查看某个 Topic 的详情
./bin/kafka-topics.sh --zookeeper localhost:2181 --describe --topic test
2.2及更高版本
./bin/kafka-topics.sh --bootstrap-server localhost:9092 --describe --topic test
windows对应的命令为:
kafka-topics.bat --zookeeper localhost:2181 --describe --topic test
6.4 修改分区数
./bin/kafka-topics.sh --zookeeper localhost:2181 --alter --topic test --partitions 2
2.2及更高版本
./bin/kafka-topics.sh--bootstrap-server localhost:9092 --alter --topic test --partitions 2
windows对应的命令为:
kafka-topics.bat --zookeeper localhost:2181 --alter --topic test --partitions 2
七、可视化工具 kafka Tool
7.1 下载
下载地址: http://www.kafkatool.com/download.html