当前位置: 首页 > news >正文

Go语言使用 kafka-go 消费 Kafka 消息教程

Go语言使用 kafka-go 消费 Kafka 消息教程

在这篇教程中,我们将介绍如何使用 kafka-go 库来消费 Kafka 消息,并重点讲解 FetchMessageReadMessage 的区别,以及它们各自适用的场景。通过这篇教程,你将了解如何有效地使用 kafka-go 库来处理消息和管理偏移量。

安装 kafka-go

首先,你需要在项目中安装 kafka-go 库。可以使用以下命令:

go get github.com/segmentio/kafka-go
初始化 Kafka Reader

为了从 Kafka 消费消息,我们首先需要配置和初始化 Kafka Reader。以下是一个简单的 Kafka Reader 初始化示例:

package mainimport ("context""log""github.com/segmentio/kafka-go"
)func main() {// 创建 Kafka ReaderkafkaReader := kafka.NewReader(kafka.ReaderConfig{Brokers:   []string{"localhost:9092"}, // Kafka broker 地址Topic:     "example-topic",            // 订阅的 Kafka topicGroupID:   "example-group",            // 消费者组 IDPartition: 0,                          // 分区号 (可选)MinBytes:  10e3,                       // 10KBMaxBytes:  10e6,                       // 10MB})defer kafkaReader.Close()
}
使用 FetchMessage 消费消息

FetchMessage 允许你从 Kafka 消费消息并手动提交偏移量,这给你对消息处理的更精确控制。以下是如何使用 FetchMessage 的示例:

func consumeWithFetchMessage() {ctx := context.Background()for {// 从 Kafka 中获取下一条消息m, err := kafkaReader.FetchMessage(ctx)if err != nil {log.Printf("获取消息时出错: %v", err)break}// 打印消息内容log.Printf("消息: %s, 偏移量: %d", string(m.Value), m.Offset)// 处理消息 (在这里可以进行你的业务逻辑)// 手动提交偏移量if err := kafkaReader.CommitMessages(ctx, m); err != nil {log.Printf("提交偏移量时出错: %v", err)}}
}
优点
  • 精确控制偏移量:在处理消息后,你可以手动选择是否提交偏移量,这样可以确保只有在消息处理成功后才提交。
  • 重试机制:可以灵活地处理失败消息,例如在处理失败时,不提交偏移量,从而实现消息的重新消费。
缺点
  • 代码复杂度增加:需要手动处理偏移量提交,会增加一些额外的代码量。
使用 ReadMessage 消费消息

ReadMessage 是一种更简单的方式,从 Kafka 中获取消息并自动提交偏移量。适用于对消费逻辑不太敏感的场景。以下是使用 ReadMessage 的示例:

func consumeWithReadMessage() {ctx := context.Background()for {// 从 Kafka 中读取下一条消息并自动提交偏移量dataInfo, err := kafkaReader.ReadMessage(ctx)if err != nil {log.Printf("读取消息时出错: %v", err)break}// 打印消息内容log.Printf("消息: %s, 偏移量: %d", string(dataInfo.Value), dataInfo.Offset)// 处理消息 (在这里可以进行你的业务逻辑)}
}
优点
  • 简单易用ReadMessage 自动提交偏移量,代码简洁,易于维护。
  • 快速开发:适合简单的消息处理逻辑和对消息可靠性要求不高的场景。
缺点
  • 缺乏灵活性:无法在处理失败时重新消费消息,因为偏移量已经自动提交。
总结选择
方法优点缺点适用场景
FetchMessage需要手动提交偏移量,精确控制消息处理和提交逻辑代码复杂度较高需要精确控制消息处理的场景,例如处理失败重试
ReadMessage简单易用,自动提交偏移量,代码更简洁无法重新消费已处理失败的消息简单的消息处理,对消息处理成功率要求不高的场景
完整示例

以下是一个完整的 Kafka 消费者示例,包括 FetchMessageReadMessage 两种方法。可以根据你的需求选择合适的方法:

package mainimport ("context""log""github.com/segmentio/kafka-go"
)func main() {// 创建 Kafka ReaderkafkaReader := kafka.NewReader(kafka.ReaderConfig{Brokers:   []string{"localhost:9092"},Topic:     "example-topic",GroupID:   "example-group",MinBytes:  10e3, // 10KBMaxBytes:  10e6, // 10MB})defer kafkaReader.Close()// 使用 FetchMessage 消费消息log.Println("开始使用 FetchMessage 消费 Kafka 消息...")consumeWithFetchMessage(kafkaReader)// 使用 ReadMessage 消费消息log.Println("开始使用 ReadMessage 消费 Kafka 消息...")consumeWithReadMessage(kafkaReader)
}func consumeWithFetchMessage(kafkaReader *kafka.Reader) {ctx := context.Background()for {m, err := kafkaReader.FetchMessage(ctx)if err != nil {log.Printf("FetchMessage 获取消息时出错: %v", err)break}log.Printf("FetchMessage 消息: %s, 偏移量: %d", string(m.Value), m.Offset)// 手动提交偏移量if err := kafkaReader.CommitMessages(ctx, m); err != nil {log.Printf("FetchMessage 提交偏移量时出错: %v", err)}}
}func consumeWithReadMessage(kafkaReader *kafka.Reader) {ctx := context.Background()for {dataInfo, err := kafkaReader.ReadMessage(ctx)if err != nil {log.Printf("ReadMessage 读取消息时出错: %v", err)break}log.Printf("ReadMessage 消息: %s, 偏移量: %d", string(dataInfo.Value), dataInfo.Offset)}
}
结语

通过本教程,你学会了如何使用 kafka-goFetchMessageReadMessage 方法消费 Kafka 消息。根据项目需求选择合适的消费方式,合理管理偏移量以确保消息处理的可靠性和效率。

相关文章:

Go语言使用 kafka-go 消费 Kafka 消息教程

Go语言使用 kafka-go 消费 Kafka 消息教程 在这篇教程中,我们将介绍如何使用 kafka-go 库来消费 Kafka 消息,并重点讲解 FetchMessage 和 ReadMessage 的区别,以及它们各自适用的场景。通过这篇教程,你将了解如何有效地使用 kafk…...

【论文笔记】Number it: Temporal Grounding Videos like Flipping Manga

🍎个人主页:小嗷犬的个人主页 🍊个人网站:小嗷犬的技术小站 🥭个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。 基本信息 标题: Number it: Temporal Grou…...

C语言菜鸟入门·关键字·int的用法

目录 1. int关键字 1.1 取值范围 1.2 符号类型 1.3 运算 1.3.1 加法运算() 1.3.2 减法运算(-) 1.3.3 乘法运算(*) 1.3.4 除法运算(/) 1.3.5 取余运算(%) 1.3.6 自增()与自减(--) 1.3.7 位运算 2. 更多关键字 1. int关键字 int 是一个关键字&#xff0…...

基于企业微信客户端设计一个文件下载与预览系统

在企业内部沟通与协作中,文件分享和管理是不可或缺的一部分。企业微信(WeCom)作为一款广泛应用于企业的沟通工具,提供了丰富的API接口和功能,帮助企业进行高效的团队协作。然而,随着文件交换和协作的日益增…...

昇思MindSpore第七课---文本解码原理

1. 文本解码原理 文本解码是将模型的输出(通常是概率分布或词汇索引)转换为可读的自然语言文本的过程。在生成文本时,常见的解码方法包括贪心解码、束搜索(BeamSearch)、随机采样等。 2 实践 2.1 配置环境 安装mindn…...

C# 数据结构之【图】C#图

1. 图的概念 图是一种重要的数据结构,用于表示节点(顶点)之间的关系。图由一组顶点和连接这些顶点的边组成。图可以是有向的(边有方向)或无向的(边没有方向),可以是加权的&#xff…...

传输控制协议(TCP)和用户数据报协议(UDP)

一、传输控制协议(TCP) 传输控制协议(Transmission Control Protocol,TCP)是一种面向连接的、可靠的、基于字节流的传输层通信协议,由 IETF 的 RFC 793 定义。 它通过三次握手建立连接,确保数…...

【Python爬虫】Scrapy框架实战---百度首页热榜新闻

如何利用Scrapy框架实战提取百度首页热榜新闻的排名、标题和链接 一、安装Scrapy库 二、创建项目(以BaiduSpider为例) scrapy startproject BaiduSpider生成每个文件的功能: 二、 创建爬虫脚本(爬虫名:news&#xff…...

采用python3.12 +django5.1 结合 RabbitMQ 和发送邮件功能,实现一个简单的告警系统 前后端分离 vue-element

一、开发环境搭建和配置 #mac环境 brew install python3.12 python3.12 --version python3.12 -m pip install --upgrade pip python3.12 -m pip install Django5.1 python3.12 -m django --version #用于检索系统信息和进程管理 python3.12 -m pip install psutil #集成 pika…...

Qt 实现网络数据报文大小端数据的收发

1.大小端数据简介 大小端(Endianness)是计算机体系结构的一个术语,它描述了多字节数据在内存中的存储顺序。以下是大小端的定义和它们的特点: 大端(Big-Endian) 在大端模式中,一个字的最高有效…...

[译]Elasticsearch Sequence ID实现思路及用途

原文地址:https://www.elastic.co/blog/elasticsearch-sequence-ids-6-0 如果 几年前,在Elastic,我们问自己一个"如果"问题,我们知道这将带来有趣的见解: "如果我们在Elasticsearch中对索引操作进行全面排序会怎样…...

Java基于SpringBoot+Vue的藏区特产销售平台

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...

12-表的约束

知识背景 表的约束,就是在表中的数据上加上约束,也被称为数据完整性约束。数据完整性约束的目的是为了不被规定的、不符合规范的数据进入数据库 在录入数据库或数据发生变化时,DBMS(数据库管理系统)会按照一定的约束条件对数据进行监测&…...

【人工智能】深度学习入门:用TensorFlow实现多层感知器(MLP)模型

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 多层感知器(MLP)是一种基础的神经网络结构,广泛应用于分类和回归任务。作为深度学习的重要组成部分,理解并实现MLP是学习更复杂神经网络模型的基础。本文将介绍多层感知器的核心概念、数学原理,并使用…...

【Go】-go中的锁机制

目录 一、锁的基础知识 1. 互斥量/互斥锁 2. CAS(compare and swap) 3. 自旋锁 4. 读写锁 5. 乐观锁 & 悲观锁 6. 死锁 二、go中锁机制 1. Mutex-互斥锁 2. RWMutex-读写锁 2.1 RWMutex流程概览 2.2 写锁饥饿问题 2.3. golang的读写锁源…...

c ++零基础可视化——vector

c 零基础可视化——vector 初始化 vector<int> v0(5); // 0 0 0 0 0 vector<int> v1(5, 1); // 1 1 1 1 1 vector<int> v2{1, 2, 3} // 1 2 3 vector<int> v3(v1); // 1 1 1 1 1 vector<vector<int>> v4(2, vect…...

Centos 7 安装 Docker 最新版本

文章目录 一、卸载旧版本二、安装最新版本docker三、问题解决3.1 启动docker报错3.2 启动容器报错 一、卸载旧版本 #如果之前安装过旧版本的Docker&#xff0c;可以使用下面命令卸载 yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest …...

构建高效在线教育:SpringBoot课程管理系统

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理在线课程管理系统的相关信息成为必然。开发…...

二进制与网络安全的关系

二进制与网络安全的关系 声明&#xff01; 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以…...

【计算机网络】网段划分

一、为什么有网段划分 IP地址 网络号(目标网络) 主机号(目标主机) 网络号: 保证相互连接的两个网段具有不同的标识 主机号: 同一网段内&#xff0c;主机之间具有相同的网络号&#xff0c;但是必须有不同的主机号 互联网中的每一台主机&#xff0c;都要隶属于某一个子网 -&…...

JavaSec-RCE

简介 RCE(Remote Code Execution)&#xff0c;可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景&#xff1a;Groovy代码注入 Groovy是一种基于JVM的动态语言&#xff0c;语法简洁&#xff0c;支持闭包、动态类型和Java互操作性&#xff0c…...

Matlab | matlab常用命令总结

常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...

IT供电系统绝缘监测及故障定位解决方案

随着新能源的快速发展&#xff0c;光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域&#xff0c;IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选&#xff0c;但在长期运行中&#xff0c;例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP

编辑-虚拟网络编辑器-更改设置 选择桥接模式&#xff0c;然后找到相应的网卡&#xff08;可以查看自己本机的网络连接&#xff09; windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置&#xff0c;选择刚才配置的桥接模式 静态ip设置&#xff1a; 我用的ubuntu24桌…...

虚拟电厂发展三大趋势:市场化、技术主导、车网互联

市场化&#xff1a;从政策驱动到多元盈利 政策全面赋能 2025年4月&#xff0c;国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》&#xff0c;首次明确虚拟电厂为“独立市场主体”&#xff0c;提出硬性目标&#xff1a;2027年全国调节能力≥2000万千瓦&#xff0…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)

RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发&#xff0c;后来由Pivotal Software Inc.&#xff08;现为VMware子公司&#xff09;接管。RabbitMQ 是一个开源的消息代理和队列服务器&#xff0c;用 Erlang 语言编写。广泛应用于各种分布…...

RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill

视觉语言模型&#xff08;Vision-Language Models, VLMs&#xff09;&#xff0c;为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展&#xff0c;机器人仍难以胜任复杂的长时程任务&#xff08;如家具装配&#xff09;&#xff0c;主要受限于人…...

scikit-learn机器学习

# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...

掌握 HTTP 请求:理解 cURL GET 语法

cURL 是一个强大的命令行工具&#xff0c;用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中&#xff0c;cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...

uni-app学习笔记三十五--扩展组件的安装和使用

由于内置组件不能满足日常开发需要&#xff0c;uniapp官方也提供了众多的扩展组件供我们使用。由于不是内置组件&#xff0c;需要安装才能使用。 一、安装扩展插件 安装方法&#xff1a; 1.访问uniapp官方文档组件部分&#xff1a;组件使用的入门教程 | uni-app官网 点击左侧…...