博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在CentOS 7上安装Kafka
阅读量:4118 次
发布时间:2019-05-25

本文共 3039 字,大约阅读时间需要 10 分钟。

简介

Kafka 是一种高吞吐的分布式发布订阅消息系统,能够替代传统的消息队列用于解耦合数据处理,缓存未处理消息等,同时具有更高的吞吐率,支持分区、多副本、冗余,因此被广泛用于大规模消息数据处理应用。Kafka 支持 及多种其它语言客户端,可与、Storm、等其它工具结合使用。

主要介绍Kafka 在Centos 7上的安装和使用(window上类似),包括功能验证和集群的简单配置,配置很重要,很多流行的开源插件学会了配置感觉就可以直接用。

安装JDK(普通用户)

Kafka 使用Zookeeper 来保存相关配置信息,Kafka及Zookeeper 依赖Java 运行环境,从下载JDK 安装包,解压安装:

$mkdir java$tar zxvf jdk-8u65-linux-x64.tar.gz

进入普通用户的初始目录通过命令 ls -la 列出所有包含隐藏文件,找到配置文件.bash_profile  修改设置Java 环境变量:

export JAVA_HOME=/home/tmp/java/jdk1.8.0_151export PATH=$JAVA_HOME/bin:$PATH  export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
 

通过执行source命令使增加的环境变量生效,再验证java是否安装成功

$source .bash_profile$java -version

安装Kafka

从下载Kafka 安装包,解压安装:

tar zxvf kafka_2.11-0.8.2.2.tgzmv kafka_2.11-0.8.2.2 kafkacd kafka

功能验证

1.启动Zookeeper

使用安装包中的脚本启动单节点Zookeeper 实例:

$./bin/zookeeper-server-start.sh -daemon ./config/zookeeper.properties[2018-05-19 04:26:59,585] INFO Reading configuration from: config/zookeeper.properties (org.apache.zookeeper.server.quorum.QuorumPeerConfig)....

2.启动Kafka 服务

使用kafka-server-start.sh 启动kafka 服务:

$./bin/kafka-server-start.sh ./config/server.properties[2018-05-19 04:28:56,115] INFO Verifying properties (kafka.utils.VerifiableProperties)[2018-05-19 04:28:56,141] INFO Property broker.id is overridden to 0 (kafka.utils.VerifiableProperties)

3.创建topic

使用kafka-topics.sh 创建单分区单副本的topic test:

$ .$/bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic hellotopicCreated topic "hellotopic".

查看topic:

$./bin/kafka-topics.sh --list --zookeeper localhost:2181hellotopictesttest1

4.产生消息

使用kafka-console-producer.sh 发送消息:

$ ./bin/kafka-console-producer.sh --broker-list localhost:9092 --topic hellotopic>hello1>world1>kafka>

5.消费消息

使用kafka-console-consumer.sh 接收消息并在终端打印:

$ ./bin/kafka-console-consumer.sh --zookeeper localhost:2181 --topic hellotopic --from-beginningUsing the ConsoleConsumer with old consumer is deprecated and will be removed in a future major release. Consider using the new consumer by passing [bootstrap-server] instead of [zookeeper].hello1world1kafka

集群配置

单机多broker 集群配置

利用单节点部署多个broker。 不同的broker 设置不同的 id,监听端口及日志目录。 例如:

cp config/server.properties config/server-1.properties

编辑配置:

config/server-1.properties:    broker.id=1    port=9093    log.dir=/tmp/kafka-logs-1

启动Kafka服务:

bin/kafka-server-start.sh config/server-1.properties &

启动多个服务,按上文类似方式产生和消费消息,当用不同的broker生产者节点发送消息时,在消费者节点都可以看到消息,因为是单机版,所以IP默认为localhost,否则在配置文件底部像下面一样显式指定IP和端口:

broker.id=1zookeeper.connect=192.168.213.4:2181,192.168.213.5:2181listeners = PLAINTEXT://192.168.213.4:9092
 

多机多broker 集群配置

分别在多个节点按上述方式安装Kafka,配置启动多个Zookeeper 实例(zookeeper集群配置可参考另一篇文章https://blog.csdn.net/LZJLZJLZJLZJLZJLZJ/article/details/59090622)。 例如: 在10.4.253.22,10.4.253.23,10.4.253.24三台机器部署,Zookeeper配置如下:

initLimit=5syncLimit=2server.1=10.4.253.22:2888:3888server.2=10.4.253.23:2888:3888server.3=10.4.253.24:2888:3888

分别配置多个机器上的Kafka服务 设置不同的broke id,zookeeper.connect设置如下:

zookeeper.connect=10.4.253.22:2181,10.4.253.23:2181,10.4.253.24:2181

启动Zookeeper与Kafka服务,按上文方式产生和消费消息,验证集群功能。

你可能感兴趣的文章
Spring的单例模式源码小窥
查看>>
后台服务的变慢排查思路(轻量级应用服务器中测试)
查看>>
MySQL中InnoDB事务的默认隔离级别测试
查看>>
微服务的注册与发现
查看>>
bash: service: command not found
查看>>
linux Crontab 使用 --定时任务
查看>>
shell编程----目录操作(文件夹)
查看>>
机器学习-----K近邻算法
查看>>
HBASE安装和简单测试
查看>>
关于程序员的59条搞笑但却真实无比的编程语录
查看>>
搞笑--一篇有趣的文章编译自一篇西班牙博客。有一位美丽的公主,被关押在一个城堡中最高的塔上,一条凶恶的巨龙看守着她,需要有一位勇士营救她…
查看>>
非常不错 Hadoop 的HDFS (Hadoop集群(第8期)_HDFS初探之旅)
查看>>
Tomcat启动错误,端口占用
查看>>
laravel 修改api返回默认的异常处理
查看>>
高德坐标转换百度坐标 javascript
查看>>
tp5封装通用的修改某列值
查看>>
laravel控制器与模型名称不统一
查看>>
vue登录拦截
查看>>
npm配置淘宝镜像仓库以及electron镜像
查看>>
linux设置开机自启动脚本的最佳方式
查看>>