kafka部署

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: kafka部署

1、下载

wget https://mirror-hk.koddos.net/apache/kafka/2.8.0/kafka_2.13-2.8.0.tgz

2、解压

tar -xzf kafka_2.13-2.8.0.tgz $ cd kafka_2.13-2.8.0


配置文件:


broker的全局唯一编号,不能重复

broker.id=0

#删除topic功能使能,新版没有找到

delete.topic.enable=true  

#处理网络请求的线程数量

num.network.threads=3

#用来处理磁盘IO的现成数量

num.io.threads=8

#发送套接字的缓冲区大小

socket.send.buffer.bytes=102400

#接收套接字的缓冲区大小

socket.receive.buffer.bytes=102400

#请求套接字的缓冲区大小

socket.request.max.bytes=104857600

#kafka运行日志存放的路径

log.dirs=/opt/module/kafka/logs

#topic在当前broker上的分区个数

num.partitions=1

#用来恢复和清理data下数据的线程数量

num.recovery.threads.per.data.dir=1

#segment文件保留的最长时间,超时将被删除

log.retention.hours=168

#配置连接Zookeeper集群地址

zookeeper.connect=hadoop102:2181,hadoop103:2181,hadoop104:2181




3、启动KAFKA环境

# Start the ZooKeeper service# Note: Soon, ZooKeeper will no longer be required by Apache Kafka.$ bin/zookeeper-server-start.sh config/zookeeper.properties

打开另一个终端会话并运行:

# Start the Kafka broker service$ bin/kafka-server-start.sh config/server.properties

将一些事件写入主题

$ bin/kafka-console-producer.sh --topic quickstart-events --bootstrap-server localhost:9092 This is my first event This is my second event

将一些事件写入主题

$ bin/kafka-console-producer.sh --topic quickstart-events --bootstrap-server localhost:9092 This is my first event This is my second event

bin/kafka-console-consumer.sh --topic quickstart-events --from-beginning --bootstrap-server localhost:9092



添加配置

bin/kafka-configs.sh --bootstrap-server broker_host:port --entity-type topics --entity-name my_topic_name --alter --add-config x=y


删除配置

bin/kafka-configs.sh --bootstrap-server broker_host:port --entity-type topics --entity-name my_topic_name --alter --delete-config x


删除topic

bin/kafka-topics.sh --bootstrap-server broker_host:port --delete --topic my_topic_name


正常关机

Kafka群集将自动检测任何代理关闭或故障,并为该计算机上的分区选择新的领导者。无论服务器发生故障还是为了维护或配置更改而有意将其关闭,都会发生这种情况。对于后一种情况,Kafka支持一种更优雅的机制来停止服务器,而不仅仅是杀死服务器。当服务器正常停止时,它具有两个优化功能,它将利用以下优势:

  1. 它将所有日志同步到磁盘上,以避免重新启动时需要进行任何日志恢复(即,验证日志尾部所有消息的校验和)。日志恢复需要时间,因此可以加快有意重启的速度。
  2. 在关闭之前,它将把服务器所领导的所有分区迁移到其他副本。这将使领导者转移更快,并将每个分区不可用的时间减少到几毫秒。

只要服务器停止运行(不是通过强行终止),就将自动同步日志,但是受控的领导者迁移需要使用特殊的设置:

     controlled.shutdown.enable=true

请注意,只有在代理上托管的所有分区都具有副本(即,复制因子大于1并且这些副本中至少有一个处于活动状态)时,受控关闭才会成功。这通常是您想要的,因为关闭最后一个副本会使该主题分区不可用。

领导平衡

每当代理停止或崩溃时,该代理分区的领导权就会转移到其他副本。重新启动代理后,它将仅是其所有分区的关注者,这意味着它将不用于客户端读取和写入。

为了避免这种不平衡,Kafka提出了首选副本的概念。如果分区的副本列表为1,5,9,则首选节点1作为节点5或9的引导者,因为它在副本列表中较早。默认情况下,Kafka集群将尝试恢复对已还原副本的领导权。此行为配置有:

     auto.leader.rebalance.enable=true

您也可以将其设置为false,但是随后您需要通过运行以下命令来手动将领导力还原到已还原的副本中:

 > bin/kafka-preferred-replica-election.sh --bootstrap-server broker_ho



检查消费者位置

有时查看消费者的位置很有用。我们有一个工具,可以显示所有使用者在使用者组中的位置以及他们在日志末尾之后的位置。要在名为my-group的使用者组上运行此工具并消耗名为my-topic的主题,该工具将如下所示:

 > bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --describe --group my-group   TOPIC                          PARTITION  CURRENT-OFFSET  LOG-END-OFFSET  LAG        CONSUMER-ID                                       HOST                           CLIENT-ID   my-topic                       0          2               4               2          consumer-1-029af89c-873c-4751-a720-cefd41a669d6   /127.0.0.1                     consumer-1   my-topic                       1          2               3               1          consumer-1-029af89c-873c-4751-a720-cefd41a669d6   /127.0.0.1                     consumer-1   my-topic  

目录
相关文章
|
消息中间件 存储 Kubernetes
Helm方式部署 zookeeper+kafka 集群 ——2023.05
Helm方式部署 zookeeper+kafka 集群 ——2023.05
640 0
|
27天前
|
消息中间件 Java Kafka
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
|
5月前
|
消息中间件 监控 Java
【一键解锁!】Kafka Manager 部署与测试终极指南 —— 从菜鸟到高手的必经之路!
【8月更文挑战第9天】随着大数据技术的发展,Apache Kafka 成为核心组件,用于处理实时数据流。Kafka Manager 提供了简洁的 Web 界面来管理和监控 Kafka 集群。本文介绍部署步骤及示例代码,助您快速上手。首先确认已安装 Java 和 Kafka。
706 4
|
5月前
|
消息中间件 域名解析 网络协议
【Azure 应用服务】部署Kafka Trigger Function到Azure Function服务中,解决自定义域名解析难题
【Azure 应用服务】部署Kafka Trigger Function到Azure Function服务中,解决自定义域名解析难题
|
5月前
|
消息中间件 Kafka Apache
部署安装kafka集群
部署安装kafka集群
|
8月前
|
消息中间件 Kafka
Kafka【部署 03】Zookeeper与Kafka自动部署脚本
【4月更文挑战第11天】Kafka【部署 03】Zookeeper与Kafka自动部署脚本
122 8
|
8月前
|
消息中间件 Kafka Docker
docker部署kafka
docker部署kafka
233 1
|
8月前
|
消息中间件 Kafka Docker
【消息中心】docker部署kafka
【消息中心】docker部署kafka
106 0
|
8月前
|
消息中间件 算法 Kafka
docker-compose部署kafka
docker-compose部署kafka
|
8月前
|
消息中间件 存储 Java
Kafka 部署教程
Kafka 部署教程

热门文章

最新文章