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

# Kafka组件化及拓展

1.Kafka

Kafka是一个开源的分布式事件流处理平台。主要用于构建实时数据管道和流处理应用程序,广泛用于日志采集。Kafka具有高吞吐量、高可用性、持久化存储、可拓展性等特点。因为公司项目中消息中间件都是用的Kafka,而且也发现在使用时有一些亮点和设计,所以想展开整理记录下,希望给有想使用Kafka作为中间件的朋友一些帮助。

2.Kafka怎么保证消息的可靠性

这里讲的可靠性主要是针对发布时的可靠性,这也是消息可靠性(发布、持久化、消费)最重要的一环,实现思路的话也很简单,简单描述就是支持发布可重试,实现如下:

  • 数据库中增加一张kafka_message表,在发布消息时先插入消息到kafka_message表
  • 增加一个定时任务,不断查询kafka_message表,遍历发布消息到kafka,然后再从kafka_message表删除发布成功的记录

另外消费时可靠性主要靠消费机制保证MessageDeliverySemantics=AT_LEAST_ONCE

3.Kafka组件化及多集群消息消费实现

在这里插入图片描述

a.组件化

组件指的是软件系统中的独立单元。因为Kafka本身已经算是一个消息组件,我在此处指的是通过将kafka、redis等中间件抽象成:组件类型、组件名称,通过这两个概念可以拿到该组件的一个集群地址去使用,在后面的内容中也会使用这种概念。

b. 多集群消息消费实现

  • 一些抽象类及枚举:

    • AbstractEventProcessor,消费者

      protected abstract void process(String msg); //消费消息实现
      
      public abstract int runners();  //消费者数量
      
      public abstract KafkaTopic topic();  //消费的主题
      
    • IConsumerGroupContext ,消费者组上下文接口,抽象了同一类消费者

      Properties getConsumerProperties();//单次拉取消息条数、序列化工具类、反序列化工具类
      
      Class<? extends AbstractEventProcessor> getProcessorClass(); //获取消息处理类
      
      MessageDeliverySemantics getDeliverySemantics(); //消费重试机制
      
      KafkaTopic getTopic(); //消息主题
       
      String getBootstrapServers();  //连接地址
      
    • KafkaClusterType : Kafka集群枚举,会配置成跟一个组件名对应的形式如

      {"TEST":"Kafka1","TESTNEW":"Kafka2"}
      
    • KafkaTopic,主题枚举,例如

      TEST_TOPIC("test", "测试topic", KafkaClusterType.TEST)
      
    • ConsumerRunnerPoolConfig,消费者线程池配置,包含Topic、processor、runner(消费者数量)

    • ConsumerRunnerPool, 消费者线程池类

  • 消费者启动的大概流程

    • 读取需要消费的Topic

    • 根据Topic 获取过滤获得对应的IConsumerGroupContext类,contextList

    • 遍历contextList,context

      • 根据context填充ConsumerRunnerPoolConfig

      • 再根据ConsumerRunnerPoolConfig去启动ConsumerRunnerPool

        核心线程池和最大线程池都是消费者数量,可以通过硬编码/配置

整体思路比较简单,但是抽象支持集群和组件配置后,可以支持集群切换或多集群,这对于灵活应对Kafka集群的切换和灾备是很有意义的。


http://www.kler.cn/a/472123.html

相关文章:

  • Bash语言的数据类型
  • H5通过URL Scheme唤醒手机地图APP
  • 分享3个国内使用正版GPT的网站【亲测有效!2025最新】
  • CV-LLM经典论文解读|VTimeLLM: Empower LLM to Grasp Video MomentsVTimeLLM:赋能大语言模型理解视频片段
  • 使用react开发一个外卖程序
  • 【Pytorch报错】AttributeError: cannot assign module before Module.__init__() call
  • Powerbi官方认证!2025年入行数据分析
  • docker学习使用
  • Spring 设计模式:经典设计模式
  • 聊天机器人Rasa面试内容整理-如何选择合适的分词器和分类器?
  • 博奥龙Nanoantibody系列IP专用抗体
  • element-ui 实现输入框下拉树组件功能
  • 【文本分类】bert二分类
  • Go语言的 的多态性(Polymorphism)核心知识
  • 【Golang 面试题】每日 3 题(二十三)
  • Python----Python基础(列表 list,切片,多维列表,相关函数,排序,元素的增加,元素的删除,元素的修改,元素的查找,列表的拷贝)
  • 【Oceanbase数据库常用巡检SQL】
  • 【Docker项目实战】使用Docker部署gallery轻量级图片管理系统
  • SSH 暴力破解攻击的诊断与防御
  • Vue进阶(贰幺叁)node 版本切换