CentOS 安装kafka

简介

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

本教程主要介绍Kafka 在Centos 7上的安装和使用,包括功能验证和集群的简单配置。

安装JDK

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

tar zxvf jdk-8u65-linux-x64.tar.gz
mv jdk1.8.0_65 java 

设置Java 环境变量:

JAVA_HOME=/opt/java
PATH=$PATH:$JAVA_HOME/bin
export JAVA_HOME PATH

也可以选择yum install安装,相应设置环境变量。

查看防火墙状态

首先查看系统防火墙是否关闭:

查看防火墙状态:firewall-cmd --state并关闭防火墙。

关闭防火墙:systemctl stop firewalld.service

禁止开机自启:systemctl disable firewalld.service

安装Kafka

官网下载Kafka 安装包,解压安装:

tar zxvf kafka_2.11-0.8.2.2.tgz
mv kafka_2.11-0.8.2.2 kafka
cd kafka

功能验证

1.启动Zookeeper

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

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

检查zookeep启动是否成功

ps -aux | grep 'zookeeper'

系统有返回说明启动成功

2.启动Kafka 服务

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

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

[2015-10-26 04:28:56,115] INFO Verifying properties (kafka.utils.VerifiableProperties)

[2015-10-26 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 test

查看topic:

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

4.生产消息

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

bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test
Hello world!
Hello Kafka!

5.消费消息

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

bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning
Hello world!
Hello Kafka!

集群配置

单机多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 集群配置

分别在多个节点按上述方式安装Kafka,配置启动多个Zookeeper 实例。 例如: 在10.4.253.22,10.4.253.23,10.4.253.24三台机器部署,Zookeeper配置如下:

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

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

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

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

### 安装 Apache Kafka on CentOS #### 准备工作 为了在CentOS上成功部署Kafka,需先确认操作系统环境已准备好。确保具备root权限或通过`sudo`命令获得相应权限。 #### 下载并解压Kafka软件包 访问[Kafka官方网站](https://kafka.apache.org/downloads),选择合适的版本下载压缩文件[^4]。对于大多数情况而言,默认推荐的最新稳定版即为合适的选择。假设选择了`kafka_2.12-3.5.1.tgz`作为目标安装包,则可以通过wget工具直接从终端获取该资源: ```bash cd /tmp/ wget https://archive.apache.org/dist/kafka/3.5.1/kafka_2.12-3.5.1.tgz tar -xzf kafka_2.12-3.5.1.tgz -C /usr/local/ ln -s /usr/local/kafka_2.12-3.5.1 /usr/local/kafka ``` #### 配置 Zookeeper 依赖项 由于Kafka依赖于Zookeeper来管理集群状态信息,在启动前应确保已经正确设置了Zookeeper实例,并处于正常运行状态[^3]。如果尚未完成此步骤,建议参照官方指南或其他教程先行搭建好Zookeeper服务端。 #### 创建 Systemd 单元文件以便管理系统级服务 为了让系统能够自动识别与控制Kafka进程,创建名为`kafka.service`的服务定义文件位于路径`/etc/systemd/system/`下[^1]。具体操作如下所示: ```ini [Unit] Description=Apache Kafka Server Documentation=http://kafka.apache.org/documentation.html Requires=zookeeper.service [Service] Type=simple ExecStart=/usr/local/kafka/bin/kafka-server-start.sh /usr/local/kafka/config/server.properties ExecStop=/usr/local/kafka/bin/kafka-server-stop.sh Restart=on-abnormal [Install] WantedBy=multi-user.target ``` 保存上述配置之后执行以下指令使更改生效: ```bash systemctl daemon-reload systemctl enable kafka.service systemctl start kafka.service ``` 最后验证两个组件均已激活并无异常报告: ```bash systemctl status zookeeper.service systemctl status kafka.service ``` 此时应该可以看到两者均显示active(running)的状态提示,表明整个安装流程顺利完成。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值