要配置kafka,首先要配置zookeeper保证集群的高可用。所以本教程包含二者的配置。java
http://kafka.apache.org/apache
一、下载kafka:https://www.apache.org/dyn/closer.cgi?path=/kafka/2.1.0/kafka_2.11-2.1.0.tgzbootstrap
二、下载zookeoper:http://mirror.bit.edu.cn/apache/zookeeper/安全
百度云盘也放的有一份哦。服务器
一、目前配置是单机环境。ssh
二、配置好本机的SSH无秘钥登陆(虽然不是必须,可是做为集群间更好的管理,这是必要的步骤)测试
三、关闭防火墙。固然,为了安全起见,最好仍是不要偷懒,应该针对性的开启须要开启的端口。命令行
四、配置java jdk环境。线程
一、解压安装包并复制zoo.cfg模板文件为zoo.cfg日志
# cd /opt/module/zookeeper-3.4.10/conf # cp zoo_sample.cfg zoo.cfg
二、配置zoo.cfg
# vi zoo.cfg
zoo.cfg配置以下:
#心跳间隔 tickTime=2000 #其余服务器链接到Leader时,最长能忍受的心跳间隔数:10*2000 = 20秒 initLimit=10 #发送消息时,多长忍受心跳间隔数:5*2000 = 10秒 syncLimit=5 #快照日志 dataDir=/opt/module/zookeeper-3.4.10/zkdata #事务日志 dataLogDir=/opt/module/zookeeper-3.4.10/zkdatalog #客户端链接zookeeper服务器的端口 clientPort=2181
三、启动服务
# ./bin/zkServer.sh start
四、查看状态
[root@h24 bin]# sh zkServer.sh status ZooKeeper JMX enabled by default Using config: /opt/module/zookeeper-3.4.10/bin/../conf/zoo.cfg Mode: standalone [root@h24 bin]# jps 1892 NameNode 2025 DataNode 7723 Jps 2207 SecondaryNameNode 7631 QuorumPeerMain(zookeeper线程)
X、其余命令
*** 中止服务 # bin/zkServer.sh stop
一、解压kafka。
二、直接启动服务
bin/kafka-server-start.sh -daemon ./config/server.properties
若是正常的话,则应该不会有任何输出信息;若是不正常,可查看详细日志文件:
tail -fn 100 logs/server.log
三、查看服务
[root@h24 kafka_2.12-2.1.0]# jps 8097 Kafka(kafka服务进程) 8179 Jps 1892 NameNode 2025 DataNode 2207 SecondaryNameNode 7631 QuorumPeerMain
一、建立话题,例如建立一个名为zhaoyi
的话题(指定分区为1):
[root@h24 kafka_2.12-2.1.0]# bin/kafka-topics.sh --create --zookeeper h24:2181 --replication-factor 1 --partitions 1 --topic zhaoyi Created topic "zhaoyi".
二、查看全部分区
[root@h24 bin]# ./kafka-topics.sh --zookeeper h24 --list zhaoyi
三、启动一个生产者(经过控制台),往topic队列(zhaoyi)中写入数据
[root@h24 bin]# ./kafka-console-producer.sh --broker-list h24:2181 --topic zhaoyi >
四、(3)执行以后进入一个等待输入命令行,即须要咱们输入消息。这时候,咱们再开启一个新的ssh通道,在该机器上启动一个消费者(经过控制台)。
[root@h24 bin]# ./kafka-console-consumer.sh --bootstrap-server h24:9092 --topic zhaoyi (空行)
执行该命令以后,控制台处于阻塞状态,由于他已经进入了监听模式,监听zhaoyi话题的任何产出信息。
(5)回到建立生产者的机器上,往等待命令行输入任何消息,敲击回车
>I love you, deer! >
(6)这时候咱们观察进入阻塞模式的消费者控制台,能够看到接收到了信息:
I love you, deer!
至此,配置结束。
X、其余命令
*** 中止服务 # bin/kafka-server-stop.sh *** 查看某个topic的消息 # bin/kafka-topics.sh --zookeeper h24:2181 --describe --topic zhaoyi