SpringBoot 集成 kafka,并消费历史事件

SpringBoot 集成 kafka,并消费历史事件

消费历史事件

上一篇文章我们讲的是 SpringBoot 集成 kafka 消费最新的事件,如果没有看过的小伙伴可以看这篇文章:SpringBoot 集成 kafka

那如果我们想消费历史的事件应该怎么办呢?

方法一:更换消费者组 id

第一步 在 application.yml 文件中新增配置
spring:application:# 应用名称name: kafka-01-basekafka:# kafka 连接地址bootstrap-servers: 39.105.58.131:9092consumer:# 让消费者从最早的事件开始消费auto-offset-reset: earliest
第二步 更换消费者组 id

我们在上一篇文章中使用的消费者组 id 为:hello-group,我们随意更换一个名字即可,我这里更换为:hello-group-02

package com.wanfeng.consumer;import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Component;/*** 作者:晚枫* 时间:2024/9/1 9:00*/
@Component
public class EventConsumer {// 采用监听的方式接收事件// topics 指定需要监听的主题// groupId 指定消费者组 id@KafkaListener(topics = "hello", groupId = "hello-group-02")public void onEvent(String event) {System.out.println("接收到的事件为:" + event);}
}

其他地方都不需要修改,然后我们启动程序去消费事件即可。

我们为什么要更换消费者组 id 呢?

因为我们已经使用过 hello-group 这个消费者 id 消费 hello 这个主题了,并且 kafka 已经保存了 hello-group 消费者组的偏移量,那么即使我们设置了 auto.offset.reset=earliest, 这个设置也不会生效,因为 kafka 只会在找不到偏移量的时候使用这个配置。

如果我们想继续使用 hello-group 这个消费者组对 hello 这个主题进行消费,并消费 hello 主题里面的历史事件可以吗?

答案是可以的,我们可以使用 kafka 提供的脚本来修改偏移量,来达到消费历史事件的目的

方法二:手动重置偏移量

在 SpringBoot 集成 kafka 这篇文章的基础上,什么都不需要修改,直接执行以下命令,就可以达到使用相同消费者组对同一个主题消费历史事件的目的了。

kafka-consumer-groups.sh --bootstrap-server localhost:9092 --group hello-group --topic hello --reset-offsets --to-earliest --execute

如果我们在执行这条命令出现以下错误的时候,我们把 Java 程序停止后再执行就可以了

Error: Assignments can only be reset if the group 'hello-group' is inactive, but the current state is Stable.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/53241.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

性能测试经典案例解析——政务查询系统

各位好,我是 道普云 一站式云测试SaaS平台。一个在软件测试道路上不断折腾十余年的萌新。 欢迎关注我的主页 道普云 文章内容具有一定门槛,建议先赞再收藏慢慢学习,有不懂的问题欢迎私聊我。 希望这篇文章对想提高软件测试水平的你有所帮…

docker拉取redis5.0.5并建立redis集群

1.配置文件 mkdir -p redis-cluster/7001/ mkdir -p redis-cluster/7002/ mkdir -p redis-cluster/7003/ mkdir -p redis-cluster/7004/ mkdir -p redis-cluster/7005/ mkdir -p redis-cluster/7006/cd redis-clustervim 7001/redis.confbind 0.0.0.0port 7001cluster-enabled…

IJCAI-信也科技杯全球AI大赛-华东师范大学亚军队伍分享

作者:彭欣怡(找不到工作版) 华东师范大学; 马千里(搬砖版) 虾皮; 指导:闫怡搏(科研版) 华东师范大学 比赛链接:https://ai.ppdai.com/mirror/goToMirrorDetailSix?mirrorId34 前言 这是我们首次参加语音领域的比赛,最初只是抱着…

【C语言】---- 复合数据类型之结构体(Struct)

在C语言中,结构体是一种用户定义的数据类型,它允许将不同类型的数据组合成一个整体。结构体在编程中扮演着非常重要的角色,它可以用于表示复杂的数据结构,提高程序的可读性和可维护性。 结构体的定义 结构体的定义使用 struct 关…

C语言程序设计 笔记代码梳理 重制版

前言 第1章 C语言的流程 1.C程序经历的六个阶段 编辑(Edit)预处理(Preprocess)编译(Compile)汇编(Assemble)链接(Link)执行(Execute) 2.C语言编写代码到运行 都是先编译,后链接,最后运行。(.c ---> .obj --->.exe)这个过…

开发适合el-dialog的拉伸拖拽自定义指令和适配自定义的图片查看组件

目录 一、应用场景 二、开发流程 1.自定义指令 2.功能原理 3.难点 三、详细开发 四、总结 一、应用场景 我之前有开发过一个图片查看的组件,这个组件可在单页面打开,也可以在弹窗里打开,但是弹窗因为是比较固定,所以有一些…

ubuntu 安装 jdk

1.安装java开发环境包jdk sudo apt update sudo apt install openjdk-8-jdk 2.配置环境变量 步骤二:配置环境变量 安装完JDK后,我们需要配置环境变量,以便系统能够正确地找到Java相关的可执行文件。打开终端并执行以下命 sudo nano /etc/environment 这…

常见限流算法-固定窗口、滑动窗口、漏桶、令牌桶

为什么需要限流 限流可以认为服务降级的一种,限流就是限制系统的输入和输出流量已达到保护系统的目的。一般来说系统的吞吐量是可以被测算的,为了保证系统的稳定运行,一旦达到的需要限制的阈值,就需要限制流量并采取一些措施以完成限制流量的目的。比如:延迟处理,拒绝处理…

OpenCV颜色空间转换(1)颜色空间转换函数cvtColor()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 将图像从一个颜色空间转换到另一个颜色空间。 此函数将输入图像从一个颜色空间转换到另一个颜色空间。在进行 RGB 颜色空间之间的转换时&#x…

怎样查看电脑文件夹大小?文件夹数据丢失怎么找回

在日常使用电脑的过程中,‌我们经常需要查看文件夹的大小,‌以便更好地管理磁盘空间。‌然而,‌有时我们可能会遇到文件夹数据丢失的问题,‌这可能是由于误删除、‌系统错误或病毒感染等多种原因造成的。‌本文旨在介绍如何查看电…

【苍穹外卖】Day 7 地址簿、下单、定时处理

1 地址簿模块 地址簿实体对象: package com.sky.entity;import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor;import java.io.Serializable;/*** 地址簿*/ Data Builder NoArgsConstructor AllArgsCon…

001集——CAD—C#二次开发入门——开发环境基本设置

CAD C#二次开发首先需要搭建一个舒服的开发环境,软件安装后,需要修改相关设置。本文为保姆级入门搭建开发环境教程,默认已成功安装vs和cad 。 第一步:创建类库 第二步:进行相关设置,如图: 下一…

绘世启动器:秋叶aaaki整合包导入最新AIStarter与问题解决

随着人工智能技术的不断发展,AI绘画工具越来越受到艺术家和爱好者的欢迎。为了更好地管理和使用这些工具,绘世启动器推出了最新版本的AIStarter,旨在为用户提供更便捷的体验。本文将详细介绍如何将秋叶aaaki整合包导入到最新的AIStarter中&am…

2024高教社杯全国大学生数学建模竞赛(A题)深度剖析 _ 建模完整过程+详细思路+代码全解析

问题1解答过程 1.1 螺线运动的基本几何模型 板凳龙的舞动路径为等距螺线。螺线是极坐标中一类常见曲线,其特点是半径随角度线性增加。我们可以用以下极坐标方程描述这条螺线: r ( θ ) p 2 π θ r(\theta) \frac{p}{2\pi} \theta r(θ)2πp​θ 其…

vue-watch监听功能(侦听器)详解使用

在Vue中,watch侦听器允许我们观察和响应Vue实例上数据的变化。当被侦听的数据发生变化时,可以执行异步操作或开销较大的操作,这是computed属性可能不适合的场景。watch侦听器提供了更灵活的方式来处理数据变化时的副作用。 基本用法 watch选…

JavaEE:多线程进阶(CAS)

文章目录 CAS什么是 CASCAS 伪代码 CAS有哪些应用CAS的ABA问题什么是ABA问题ABA问题带来的BUG解决方案 CAS 什么是 CAS CAS: 全称Compare and swap,字面意思:”比较并交换“,一个 CAS 涉及到以下操作: 我们假设内存中的原数据V,旧的预期值A…

刷题记录(2)

1. HWOD机试 - 模拟消息队列(100) package com.yue.test;import org.junit.Test;import java.util.ArrayList; import java.util.Arrays; import java.util.LinkedList; import java.util.List;/*** Author: 夜雨* Date: 2021-12-08-10:31* Description:* Version 1.0*/ public…

【Android】ViewPager基本用法总结

文章目录 一、添加ViewPager控件二、构建适配器类三、在 MainActivity 中设置适配器示例一:图片切换适配器MainActivity 示例二:Fragment切换适配器FragmentMainActivity ViewPager 是 Android 中一个用于在同一屏幕上滑动不同页面(通常是左右…

计算机网络13——IM聊天系统——网络功能实现——UDP

目录 1、类的成员变量 2、魔鬼数字 3、创建接收数据的线程 4、线程函数 5、防止旧接收到的数据被新数据覆盖掉 6、拷贝用的函数:memcpy_s 7、回收线程资源 8、计数器-1 (1)结束线程工作 (2)关闭句柄 测试代码 1、类的成员变量 同一个类中的多个函数中都要使用…

OBS怎么设置录制配置?3个电脑录屏小技巧妥妥教会你

OBS Studio是一款广受好评的开源录屏和直播软件,它以其强大的功能和用户友好的操作界面而闻名。对于初次接触OBS的用户来说,可能会对软件的众多按钮感到困惑。本文将为你提供一份简洁明了的OBS录屏指南,帮助你快速上手。 演示机型&#xff1a…