Windows下使用Kafka

一.准备ZooKeeper

从官网下载最新稳定版本:3.5.6。下载后解压到本地,在 conf 目录下找到 zoo_sample.cfg ,重命名为 zoo.cfg 修改里面的数据存放目录:

#dataDir=/tmp/zookeeper
dataDir=D:/hecg/apache-zookeeper-3.5.6-bin/data

使用 git 命令行客户端启动:

## 测试启动,正常
$ ./zkServer.sh start
/c/ProgramData/Oracle/Java/javapath/java
ZooKeeper JMX enabled by default
Using config: D:hecgapache-zookeeper-3.5.6-binconfzoo.cfg
Starting zookeeper ... STARTED
## 测试停止,正常
$ ./zkServer.sh stop
/c/ProgramData/Oracle/Java/javapath/java
ZooKeeper JMX enabled by default
Using config: D:hecgapache-zookeeper-3.5.6-binconfzoo.cfg

二.准备Kafka

从官网下载的版本为:kafka_2.12-2.4.0

2.1 修改配置文件
  • 修改 config 目录下的 kafka 配置文件,修改日志存放目录:

    #log.dirs=/tmp/kafka-logs
    log.dirs=D:/Program/kafka_2.12-2.4.0/data/kafka-logs
    
  • 修改 config 目录下的 zookeeper 配置文件,修改数据存放目录:

    #dataDir=/tmp/zookeeper
    dataDir=D:/hecg/kafka_2.12-2.4.0/data/zookeeper
    
2.2 启动ZooKeeper:
$ bin/zookeeper-server-start.sh config/zookeeper.properties
[2020-01-20 14:46:01,282] INFO Reading configuration from: config/zookeeper.properties (org.apache.zookeeper.server.quorum.QuorumPeerConfig)
[2020-01-20 14:46:01,283] WARN configzookeeper.properties is relative. Prepend. to indicate that you're sure! (org.apache.zookeeper.server.quorum.QuorumPeerConfig)
[2020-01-20 14:46:01,284] INFO clientPortAddress is 0.0.0.0/0.0.0.0:2181 (org.apache.zookeeper.server.quorum.QuorumPeerConfig)
...
2.3 启动Kafka Server:
$ bin/kafka-server-start.sh config/server.properties
[2020-01-20 14:50:57,961] INFO Registered kafka:type=kafka.Log4jController MBean (kafka.utils.Log4jControllerRegistration$)
[2020-01-20 14:50:58,388] INFO starting (kafka.server.KafkaServer)
[2020-01-20 14:50:58,389] INFO Connecting to zookeeper on localhost:2181 (kafka.server.KafkaServer)
[2020-01-20 14:50:58,407] INFO [ZooKeeperClient Kafka server] Initializing a new session to localhost:2181. (kafka.zookeeper.ZooKeeperClient)
[2020-01-20 14:50:58,412] INFO Client environment:zookeeper.version=3.5.6-c11b7e26bc554b8523dc929761dd28808913f091, built on 10/08/2019 20:18 GMT (org.apache.zookeeper.ZooKeeper)
...
2.4 创建Topic
  • 创建Topic:

    $ bin/kafka-topics.sh --create --bootstrap-server localhost:9092 --replication-factor 1 --partitions 1 --topic test
    
  • 列出所有的Topic:

    $ bin/kafka-topics.sh --list --bootstrap-server localhost:9092
    test
    

期间出现了小插曲:加载不到log4j的配置文件:写死配置文件后好了

$ bin/kafka-topics.sh --list --bootstrap-server localhost:9092
log4j:ERROR Could not read configuration file from URL [file:/d/hecg/kafka_2.12-2.4.0/bin/../config/tools-log4j.properties].
java.io.FileNotFoundException: dhecgkafka_2.12-2.4.0in..config	ools-log4j.properties
...

## 修改 kafka-run-class.sh line 194
#LOG4J_DIR="$base_dir/config/tools-log4j.properties"
LOG4J_DIR="D:/hecg/kafka_2.12-2.4.0/config/tools-log4j.properties"
2.5 发送和接收消息测试
  • 指定Topic发送消息:

    $ bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test
    >This is a message
    >This is another message
    >hello hecg
    >
    
  • 指定Topic接收消息:

    $ bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning
    This is a message
    This is another message
    hello hecg
    
原文地址:https://www.cnblogs.com/HeCG95/p/12218214.html