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

架构师之 Kafka 核心概念入门

Kafka 核心概念

作为架构师,理解 Kafka 的核心概念至关重要。这些概念是构建高效、可靠的 Kafka 系统的基础。
以下是需要掌握的 Kafka 核心概念及其详细说明:

1. Topic

  • 定义:Topic 是 Kafka 中用于存储和分类消息的逻辑命名空间。每个 Topic 代表一类数据流,
    例如日志、交易记录等。

  • 作用:通过 Topic,可以将不同类型的消息分开,方便管理和消费。

  • 操作:创建、删除和列出现有的 Topic。

    # 创建一个新的 Topic
    kafka-topics.sh --create --topic my_topic --bootstrap-server localhost:9092 --partitions 3 --replication-factor 2# 列出所有 Topic
    kafka-topics.sh --list --bootstrap-server localhost:9092# 删除一个 Topic
    kafka-topics.sh --delete --topic my_topic --bootstrap-server localhost:9092
    

2. Partition

  • 定义:Partition 是 Topic 的子集,是一个有序的、不可变的消息队列。每个 Partition 可以存储多个消息。
  • 作用:通过 Partition,可以实现消息的并行处理,提升系统的吞吐量。
  • 操作:创建 Topic 时指定 Partition 数量,或者在现有 Topic 上增加 Partition。
    # 增加现有 Topic 的 Partition 数量
    kafka-topics.sh --alter --topic my_topic --partitions 5 --bootstrap-server localhost:9092
    

3. Offset

  • 定义:Offset 是 Partition 中每条消息的唯一标识。Offset 是一个递增的整数,用于定位和跟踪消息。
  • 作用:通过 Offset,可以确保每条消息在消费时的顺序和位置。
  • 操作:消费者通过 Offset 跟踪消费进度,支持自动和手动提交 Offset。
    // 消费者配置示例
    Properties props = new Properties();
    props.put("bootstrap.servers", "localhost:9092");
    props.put("group.id", "test_group");
    props.put("enable.auto.commit", "true");
    props.put("auto.commit.interval.ms", "1000"
http://www.lryc.cn/news/378094.html

相关文章:

  • Redis通用命令详解
  • 物联网设备安装相关知识整理
  • React实现H5手势密码
  • [leetcode hot 150]第十五题,三数之和
  • 视频AI分析定时任务思路解析
  • tcp 粘包和拆包 及 解决粘包方案
  • 【2024泰迪杯】B 题:基于多模态特征融合的图像文本检索20页论文及Python代码
  • 华为设备telnet 远程访问配置实验简述
  • 在HTML中,如何正确使用语义化标签?
  • WHAT - 高性能和内存安全的 Rust(一)
  • 八、C#运算符
  • 【HiveSQL】join关联on和where的区别及效率对比
  • 如何解决windows自动更新,释放C盘更新内存
  • 初学51单片机之PWM实例呼吸灯以及遇到的问题(已解答)
  • 手机天线都去哪里了?
  • 计算机网络 —— 应用层(电子邮件)
  • Java18新特性(极简)
  • vscode连接ssh远程服务器
  • 【趣味测试】
  • 数据结构经典面试之数组——C#和C++篇
  • docker的基本知识
  • React Native性能优化红宝书
  • 后端不提供文件流接口,前台js使用a标签实现当前表格数据(数组非blob数据)下载成Excel
  • 如何使用ChatGPT辅助设计工作
  • hadoop服务器启动后无法执行hdfs dfs命令
  • Flink 1.19.1 standalone 集群模式部署及配置
  • 【深度学习】GELU激活函数是什么?
  • 如何编译和运行您的第一个Java程序
  • vscode用vue框架写一个登陆页面
  • 腾讯云API安全保障措施?有哪些调用限制?