在前一篇文章《大数据学习初级入门教程(三) —— Kafka 2.2.0 单节点的安装、启动和测试》中,简要说明了在一台测试服务器上如何安装单节点 Kafka 并做了消息发送和获取的测试,这篇主要说明一下在一台机器上如何配置多个节点,需要在前一篇文章操作后的基础上,搭建 Kafka 伪分布式集群,这里配置 3 个代理节点。
为每个代理节点创建一个配置文件,可以直接复制已有的配置文件,命令如下:
# cp config/server.properties config/server2.properties
# cp config/server.properties config/server3.properties
vi config/server2.properties
修改其中的部分配置,如下:
broker.id=1
listeners=PLAINTEXT://:9093
log.dirs=/tmp/kafka-logs-2
vi config/server3.properties
修改其中的部分配置,如下:
broker.id=2
listeners=PLAINTEXT://:9094
log.dirs=/tmp/kafka-logs-3
像启动单节点 Kafka 服务一样,启动各个服务。
# bin/zookeeper-server-start.sh config/zookeeper.properties &
# bin/kafka-server-start.sh config/server.properties &
# bin/kafka-server-start.sh config/server2.properties &
# bin/kafka-server-start.sh config/server3.properties &
这次创建一个复制因子为 3 的新主题:
# bin/kafka-topics.sh --create --bootstrap-server localhost:9092 --replication-factor 3 --partitions 1 --topic test3
查看 Kafka 中有哪些已创建的主题,可以用以下命令:
# bin/kafka-topics.sh --list --bootstrap-server localhost:9092
test
test3
通过上面的步骤,目前已经搭建了一个有 3 个代理节点的伪分布式集群,如何知道代理正在做什么呢?可以通过“describe topics”命令查看运行的集群信息:
# bin/kafka-topics.sh --describe --bootstrap-server localhost:9092 --topic test3
Topic:test3 PartitionCount:1 ReplicationFactor:3 Configs:segment.bytes=1073741824
Topic: test3 Partition: 0 Leader: 2 Replicas: 2,1,0 Isr: 2,1,0
行信息给出了所有分区的摘要,每个附加行提供有关一个分区的信息。由于此主题只有一个分区,因此只有一行。
运行生产者,然后键入一些消息,发送到服务器。默认情况下,每行将作为单独的消息发送。
# bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test3
>my test message 1
>
运行消费者,从服务中获取已有的一些消息。
# bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test3 --from-beginning
my test message 1
从第六步中可以看到,第三个代理节点是集群的 Leader,因为第三个代理节点的配置文件中配置的 broker.id=2。这里杀掉该节点的进程:
# ps aux | grep server3.properties
root 2651 2.4 20.1 4733556 202656 pts/3 Sl 02:03 0:32 java ...
# kill -9 2651
# bin/kafka-topics.sh --describe --bootstrap-server localhost:9092 --topic test3
Topic:test3 PartitionCount:1 ReplicationFactor:3 Configs:segment.bytes=1073741824
Topic: test3 Partition: 0 Leader: 1 Replicas: 2,1,0 Isr: 1,0
可以看到集群的 Leader 变为第二个代理节点。也可以再次运行第八步中的消费命令,可以看到数据还是可以正常消费的。
# bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test3 --from-beginning
my test message 1
到此为止,伪分布式 Kafka 集群的安装、配置、启动及测试完成。