Kafka集群搭建

环境准备

我使用的是CentOS-6.7版本的3个虚拟机,主机名为hadoop01、hadoop02、hadoop03。这3台虚拟机既是Zookeeper集群,又是Kafka集群(但在生产环境中,这两个集群通常会部署在不同的机架上)。我将使用hadoop用户来搭建集群(在生产环境中,root用户通常不被允许随意使用)。关于虚拟机的安装,可以参考以下两篇文章:在Windows中安装一台Linux虚拟机,以及通过已有的虚拟机克隆四台虚拟机。Zookeeper集群参考zookeeper-3.4.10的安装配置。Kafka安装包的下载地址为:https://www.php.cn/link/90797bef9ef6175e04f3c9383568f9e4。

将Kafka安装包上传到服务器并解压

[hadoop@hadoop01 ~]$ tar -zxvf /opt/soft/kafka_2.11-0.10.2.1.tgz -C /opt/apps/

进入Kafka的config目录下,修改server.properties文件

[hadoop@hadoop01 ~]$ cd /opt/apps/kafka_2.11-0.10.2.1/config/[hadoop@hadoop01 config]$ vim server.propertiesbroker.id=1host.name=192.168.42.101log.dirs=/opt/data/kafkazookeeper.connect=hadoop01:2181,hadoop02:2181,hadoop03:2181

说明:

只需修改上述列出的4个配置,其余保持默认。host.name这个配置在原文件中不存在,需要手动添加,建议使用IP地址而不是主机名。这个配置在Kafka单节点或伪分布式集群中不需要设置。broker.id在每个节点上必须唯一,我设置hadoop01的broker.id=1,hadoop02的broker.id=2,hadoop03的broker.id=3log.dirs指定Kafka数据的存储位置,默认的tmp目录会定期清空,因此需要修改,并且在启动Kafka集群前需要创建指定的目录。zookeeper.connect如果不指定,将使用Kafka自带的Zookeeper。

分发安装包

[hadoop@hadoop01 apps]$ scp -r kafka_2.11-0.10.2.1 hadoop03:`pwd`

分别修改hadoop02和hadoop03的broker.id和host.name

在每个节点下创建log.dirs指定的目录

启动Zookeeper服务

[hadoop@hadoop01 ~]$ zkServer.sh start[hadoop@hadoop02 ~]$ zkServer.sh start[hadoop@hadoop03 ~]$ zkServer.sh start

在3个节点上都启动Kafka

[hadoop@hadoop01 kafka_2.11-0.10.2.1]$ bin/kafka-server-start.sh -daemon config/server.properties[hadoop@hadoop02 kafka_2.11-0.10.2.1]$ bin/kafka-server-start.sh -daemon config/server.properties[hadoop@hadoop03 kafka_2.11-0.10.2.1]$ bin/kafka-server-start.sh -daemon config/server.properties# -daemon选项的意思是后台启动服务

验证Kafka服务是否启动

Kafka集群搭建

集简云 集简云

软件集成平台,快速建立企业自动化与智能化

集简云 22 查看详情 集简云 测试Kafka集群

(1) 在任意节点上创建”test01″这个topic

[hadoop@hadoop01 kafka_2.11-0.10.2.1]$ bin/kafka-topics.sh --create --zookeeper hadoop01:2181,hadoop02:2181,hadoop03:2181 --replication-factor 1 --partitions 1 --topic test01

(2) 在hadoop01上开启kafka-console-producer,向test01这个topic中写入数据

[hadoop@hadoop01 kafka_2.11-0.10.2.1]$ bin/kafka-console-producer.sh --broker-list hadoop01:9092,hadoop02:9092,hadoop03:9092 --topic test01

(3) 在另一台节点上开启kafka-console-consumer,将hadoop01节点接收到的数据打印出来

[hadoop@hadoop02 kafka_2.11-0.10.2.1]$ bin/kafka-console-consumer.sh --zookeeper hadoop01:2181,hadoop02:2181,hadoop03:2181 --topic test01 --from-beginning

Kafka集群搭建

Kafka集群搭建成功!

以上就是Kafka集群搭建的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/618869.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月11日 05:28:34
下一篇 2025年11月11日 05:31:37

相关推荐

  • Golang如何使用t.Skip跳过测试

    使用 t.Skip 可在Go测试中根据条件跳过测试函数,如平台限制或环境依赖未满足时,调用 t.Skip(“原因”) 会立即终止执行并标记为跳过;t.SkipNow() 等价于无消息跳过;通过 testing.Short() 可在 go test -short 模式下跳过耗时…

    2025年12月16日
    000
  • 使用 Go 语言检查 RS232 线路状态

    本文介绍了如何在 Go 语言中使用 github.com/schleibinger/sio 库检查 RS232 线路状态,例如 RTS、CTS、DTR 和 DSR 引脚的状态。由于标准库可能不支持硬件流控制,本文将引导你使用替代库来实现线路状态的检测,并提供相关注意事项,帮助你在 Raspberry…

    2025年12月16日
    000
  • Golang gRPC流式数据处理与优化示例

    gRPC流式传输适用于实时数据场景,文章以日志推送为例,介绍Server Streaming实现方式,涵盖proto定义、服务端与客户端代码,并强调性能优化如控制发送频率、启用压缩、设置超时限流及连接恢复策略。 在使用 Golang 构建高性能微服务时,gRPC 是首选通信框架之一。相比传统的 RE…

    2025年12月16日
    000
  • Go语言GOPATH:多项目管理的正确实践

    go语言的gopath环境变量是管理项目和依赖的核心机制。它定义了go项目源代码、编译包和可执行文件的存放位置。理解gopath的统一管理方式,可以避免为每个项目创建独立的`src/pkg/bin`目录的误区,从而高效地组织和获取外部包,实现多个go项目的无缝共存。 引言:理解Go项目组织的核心——…

    2025年12月16日
    000
  • Golang如何使用Kubernetes CronJob定时任务

    答案是使用Go编写程序并由Kubernetes CronJob定时运行。具体步骤:1. 编写Go程序实现任务逻辑;2. 构建Docker镜像并推送到镜像仓库;3. 创建CronJob YAML配置,设置执行周期和容器镜像;4. 应用配置并查看Pod日志验证执行结果。核心在于将Go程序打包为镜像后交由…

    2025年12月16日
    000
  • Golang如何配置跨平台开发环境

    配置Golang跨平台开发环境需统一工具链、启用Go Modules并设置GOOS/GOARCH进行交叉编译,结合VS Code或CI/CD实现多平台构建。 配置Golang跨平台开发环境的关键在于统一工具链、合理设置构建目标和使用现代化的依赖管理。只要基础环境搭好,Go天生支持多平台编译的特性就能…

    2025年12月16日
    000
  • Go语言中并发安全地操作结构体切片

    本文深入探讨了在Go语言中并发操作结构体切片时遇到的两大核心问题:切片值语义导致的修改不可见性,以及并发访问共享数据引发的数据竞争。文章详细阐述了通过返回新切片或传递结构体指针来正确修改切片的方法,并提供了基于通道(channels)和互斥锁(sync.Mutex)的多种并发安全策略,旨在帮助开发者…

    2025年12月16日
    000
  • Go语言并发处理结构体切片:深度解析引用与同步策略

    本文深入探讨了go语言中并发处理结构体切片时遇到的核心挑战,包括切片扩容时值传递的限制以及多goroutine并发修改导致的竞态条件。文章详细介绍了两种有效的切片操作方式(返回新切片或传递结构体指针),并重点阐述了实现并发安全的多种策略,如利用通道进行协调、在结构体中嵌入`sync.mutex`,以…

    2025年12月16日
    000
  • Golang如何操作目录和文件路径

    Go语言通过path/filepath和os包实现跨平台路径操作。1. 使用filepath.Join拼接路径,自动适配分隔符;2. 用Dir、Base、Ext提取路径信息;3. Clean清理冗余,Abs转绝对路径;4. Walk遍历目录树;5. os.Stat判断路径存在性与类型,确保操作安全可…

    2025年12月16日
    000
  • Go语言中并发安全地操作结构体切片:引用与同步机制

    本文深入探讨了在go语言中并发操作结构体切片时遇到的挑战及解决方案。首先阐明了切片作为值类型在传递时可能导致的问题,并提供了两种非并发场景下的修改切片方法。接着,重点介绍了三种实现并发安全的策略:使用通道进行解耦、在结构体内部嵌入互斥锁保护共享数据,以及使用全局互斥锁保护特定逻辑。文章通过示例代码和…

    2025年12月16日
    000
  • Go程序中ptrace系统调用追踪的挑战与替代方案

    尝试使用`ptrace`追踪go程序中的系统调用通常会导致进程挂起和结果不一致。这主要是因为go运行时(runtime)将goroutine多路复用到操作系统线程上,并且系统调用可能在与`ptrace`追踪的线程不同的线程上执行,从而使得传统的单线程`ptrace`机制失效。本文将深入探讨这一冲突,…

    2025年12月16日
    000
  • Go语言跨平台开发:使用构建约束处理平台特定代码

    在go语言跨平台开发中,处理操作系统或架构特定的代码(如cgo调用windows api)是常见挑战。本文详细介绍go语言的构建约束(build constraints)机制,包括`// +build`指令、文件命名约定以及预定义标签,帮助开发者高效地在不同平台上编译和排除特定文件,确保代码的灵活性…

    2025年12月16日
    000
  • Go语言在树莓派上操作GPIO:使用davecheney/gpio库实践指南

    本文旨在指导读者如何利用go语言在树莓派上进行gpio操作,重点介绍并推荐使用`davecheney/gpio`库。我们将探讨该库的安装、基本用法,并通过一个经典的led闪烁示例,展示如何设置引脚模式、读取和写入引脚状态,从而实现对树莓派硬件的有效控制。 树莓派GPIO与Go语言编程概述 树莓派的通…

    2025年12月16日
    000
  • Go语言跨平台开发:使用构建约束和文件命名实现条件编译

    本文深入探讨go语言中实现条件编译的关键机制,包括`+build`指令和文件命名约定。通过这些方法,开发者可以根据目标操作系统和架构灵活地排除或包含源文件,从而有效管理平台特有的代码依赖,解决跨平台开发中的编译难题,确保代码在不同环境中顺畅构建和运行。 在Go语言的跨平台开发中,经常会遇到某些代码模…

    2025年12月16日
    000
  • 如何在Linux环境中配置Golang开发工具

    安装Go并配置环境变量,设置模块代理与VS Code开发工具,创建项目验证运行调试功能。 在Linux系统中配置Golang开发环境并不复杂,只要按步骤设置好Go语言运行时、工作区和开发工具,就能快速开始编码。以下是详细的配置流程。 安装Go语言环境 从官方下载适合你系统的Go二进制包,推荐使用稳定…

    2025年12月16日
    000
  • 在 Go (Golang) 中枚举注册表值

    本文介绍了如何在 Go (Golang) 中枚举 Windows 注册表中的值。通过使用 `golang.org/x/sys/windows/registry` 包,我们可以安全有效地读取注册表键值,并将它们转换为字符串,以便在应用程序中使用。文章提供了详细的代码示例,展示了如何打开注册表键、读取键…

    2025年12月16日
    000
  • Go 并发修改结构体切片:从切片语义到并发安全机制

    本文深入探讨了在 go 语言中并发修改结构体切片时遇到的两大核心问题:切片操作的语义行为(尤其是 `append` 导致的切片重分配)以及并发环境下的数据竞争。文章详细介绍了通过返回新切片、传递结构体指针来正确处理切片修改,并提供了使用 channel、内嵌 `sync.mutex` 或全局 `sy…

    2025年12月16日
    000
  • Go语言条件编译:利用构建约束实现跨平台代码管理

    go语言通过构建约束(build constraints)提供了一种优雅的机制,允许开发者根据目标操作系统、架构、编译器或自定义标签,有条件地编译特定源文件。这对于处理平台特有依赖,如cgo与windows api的集成,或在不同系统上模拟功能,提供了强大的支持,确保代码在多种环境中高效且无缝地运行…

    2025年12月16日
    000
  • Go语言操作通用输入输出(GPIO)指南

    本文旨在为go语言开发者提供一套在嵌入式设备上操作通用输入输出(gpio)的实用指南。我们将介绍如何利用第三方库,特别是`davecheney/gpio`包,来实现gpio引脚的读写控制。通过具体的代码示例,您将学会如何设置引脚模式、控制电平输出以及读取引脚状态,从而在go项目中实现与外部硬件的交互…

    2025年12月16日
    000
  • Golang如何在Windows中配置WSL开发环境

    启用WSL并安装Linux发行版;2. 在WSL中下载、解压Go并配置PATH;3. 设置GOPATH和GOBIN(可选);4. 使用VS Code Remote-WSL插件进行开发,实现Windows与Linux环境融合的Go开发体验。 在Windows上使用WSL(Windows Subsyst…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信