每天几道面试题|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):消息既不会丢失也不会重复传递。
相关推荐
amazinging3 小时前
北京-4年功能测试2年空窗-报培训班学测开-第五十四天
python·学习·面试
山猪打不过家猪4 小时前
(一)Eshop(异常处理中间件)
分布式
cui_hao_nan6 小时前
消息队列总结
kafka·rabbitmq·rocketmq
DoraBigHead7 小时前
手写 `new`、`call`、`apply`、`bind` + V8 函数调用机制解密
前端·javascript·面试
remCoding8 小时前
Java大厂面试实录:从Spring Boot到AI微服务架构的深度解析
spring boot·redis·kafka·java面试·spring ai·jakarta ee·ai微服务
remCoding11 小时前
Java大厂面试实录:从Spring Boot到AI微服务架构的深度拷问
spring boot·spring cloud·kafka·java面试·jakarta ee·ai面试·ai微服务
lifallen12 小时前
KRaft 角色状态设计模式:从状态理解 Raft
java·数据结构·算法·设计模式·kafka·共识算法
库森学长12 小时前
索引失效的场景有哪些?
后端·mysql·面试
种子q_q13 小时前
面试官:什么是Spring的三级缓存机制
后端·面试
weixin_4708802614 小时前
行为型设计模式:解释器模式
设计模式·面试·解释器模式·代码规范·个人提升