每天几道面试题|Kafka基础概念(一)

文章目录

  • [什么是 Apache Kafka?它是用来解决什么问题的?](#什么是 Apache Kafka?它是用来解决什么问题的?)
  • [Kafka 的主要组件有哪些?它们各自的作用是什么?](#Kafka 的主要组件有哪些?它们各自的作用是什么?)
  • [Kafka 中的生产者和消费者是什么?它们之间的关系是怎样的?](#Kafka 中的生产者和消费者是什么?它们之间的关系是怎样的?)
  • [Kafka 中的分区是什么?为什么要使用分区?](#Kafka 中的分区是什么?为什么要使用分区?)
  • [Kafka 中的消息保证是指什么?有哪些消息保证级别?](#Kafka 中的消息保证是指什么?有哪些消息保证级别?)

Hello 大家好,我是阿月,保持学习,老年痴呆追不上我。学习Kafka的时候,可以考虑从基础概念、架构和应用场景等三个层次着手,今天先来复习基础概念。

什么是 Apache Kafka?它是用来解决什么问题的?

  • Apache Kafka 是一个分布式流处理平台和消息队列系统,设计用于高可靠性、高吞吐量的数据传输,以及实时数据处理应用程序的构建。它解决了大规模数据处理和实时数据流的可靠传输问题。

Kafka 的主要组件有哪些?它们各自的作用是什么?

  • 生产者(Producer):负责向 Kafka 主题发送消息。
  • 消费者(Consumer):从 Kafka 主题订阅并消费消息。
  • 主题(Topic):消息的逻辑容器,数据存储在 Kafka 中的逻辑组织单元。
  • 分区(Partition):每个主题可分成一个或多个分区,每个分区是一个有序的消息队列。
  • 偏移量(Offset):每条消息在分区内的唯一标识符。
  • Kafka 集群:由多个 Kafka 服务器节点组成的集群,负责消息的存储和传输。

Kafka 中的生产者和消费者是什么?它们之间的关系是怎样的?

  • 生产者负责向 Kafka 主题发送消息,消费者则从 Kafka 主题订阅并消费消息。生产者和消费者是独立的客户端程序,彼此之间没有直接联系,它们通过 Kafka 集群进行通信。生产者将消息发送到主题的指定分区,而消费者从一个或多个分区订阅消息,并按照一定的顺序处理消息。

Kafka 中的分区是什么?为什么要使用分区?

  • 分区是 Kafka 主题的物理存储单元,每个分区是一个有序的消息队列。分区使得 Kafka 能够水平扩展,允许集群中的多个服务器并行处理消息。通过分区,Kafka 实现了高吞吐量和负载均衡,同时允许消息持久化和容错处理。

Kafka 中的消息保证是指什么?有哪些消息保证级别?

  • 消息保证指的是 Kafka 提供的消息传递的可靠性保证级别。
  • 主要的消息保证级别包括:
    • 最多一次(At most once):消息可能会丢失,但不会重复传递。
    • 至少一次(At least once):消息可以重复传递,但不会丢失。
    • 精确一次(Exactly once):消息既不会丢失也不会重复传递。
相关推荐
JAVA面经实录9176 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
小程故事多_808 小时前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
迦南的迦 亚索的索13 小时前
AI_11_Coze_AI面试助手
人工智能·面试·职场和发展
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
KmSH8umpK14 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第三篇
redis·分布式·wpf
逻辑驱动的ken15 小时前
Java高频面试场景题19
java·开发语言·面试·职场和发展·求职招聘
KmSH8umpK17 小时前
SpringBoot 分布式锁实战:从单机锁到Redis分布式锁全覆盖,解决超卖、重复下单、幂等并发问题
spring boot·redis·分布式
笨鸟先飞的橘猫18 小时前
通用后端面试题收集(持续中)
面试
KmSH8umpK20 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案
redis·分布式·wpf