Kafka学习小结

本文详细介绍了Kafka的基本概念、安装使用、重要特性以及分区副本机制。Kafka作为消息队列中间件,适用于异步处理、系统解耦和流量削峰等场景。文章还探讨了Kafka的生产者、消费者模型,以及消费者组和幂等性设置,最后讨论了分区写入策略和Consumer Group Rebalance机制。
摘要由CSDN通过智能技术生成

一. Kafka简介

1. 消息队列

  • 消息队列 ---- 用于存放消息的组件

  • 可以将消息存放到队列里, 也可以从消息队列中获取消息

  • 很多时候消息队列不是一个永久性的存储, 是作为临时存储存在的 (设定一个期限, 设置消息在MQ中的保存时间)

  • 消息队列中间件: 如Kafka, Active MQ, RabbitMQ, RocketMQ, ZeroMQ

2. Kafka的应用场景

  • 异步处理:

    • 可以将一些比较耗时的操作放在其他系统中, 通过消息队列将需要进行处理的消息进行存储, 其他系统可以消费队列中的数据
    • 常见的有:发送短信验证码,发送邮件
  • 系统解耦:

    • 原先一个微服务是通过接口(HTTP)调用另外一个微服务,这是高耦合的, 只要接口发生变化就会导致系统不可用
    • 使用消息队列可以将系统进行耦合, 现在一个微服务可以将消息放入到队列中, 另一个微服务可以从消息队列中把消息取出来进行处理, 进行系统解耦
  • 流量削峰

    • 因为消息队列是低延迟, 高可靠, 高吞吐的, 可以应对大量并发
  • 日志处理

    • 可以使用消息队列作为临时存储, 或者一种通信管道

3. 消息队列的两种模型

  • 生产者, 消费者模型

    • 生产者负责将消息生产到MQ中
    • 消费者从MQ中获取消息
    • 生产者和消费者是解耦的, 生产者和消费者可能属于不同的程序
  • 消息队列的模式

    • 点对点: 一个消费者消费一个消息
    • 发布订阅: 多个消费者消费可以一个消息

二. Kafka安装和使用

1. 安装Kafka集群

  • 1.1 解压安装包, 修改server.properties
#broker的ID,全局唯一编号, 不能重复  假设安装目录为 /opt/module/kafka
broker.id<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值