Kafka -- 异步通信原理

本文介绍了Kafka实现异步通信的原理,包括观察者模式、生产者消费者模式、缓冲区的作用以及数据单元的设计要点。通过缓冲区解耦生产者和消费者,支持并发与忙闲不均的场景,确保数据单元的完整性和独立性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异步通信原理

1.1 观察者模式

  • 观察者模式(Observer),又叫发布-订阅模式(Publish/Subscribe)

  • 定义对象间一种一对多的依赖关系,使得每当一个对象改变状态,则所有依赖于它的对象都会得到通知并自动更新

  • 一个对象(目标对象)的状态发生改变,所有的依赖对象(观察者对象)都将得到通知。

在这里插入图片描述

1.2 生产者消费者模式

  • 传统模式

    • 生产者直接将消息传递给指定的消费者
    • 耦合性特别高,当生产者或者消费者发生变化,都需要重写业务逻辑。
  • 生产者消费者模式

    • 通过一个容器来解决生产者和消费者的强耦合问题,生产者和消费者彼此直接不直接通讯,而通过阻塞队列来进行通讯
    • 在这里插入图片描述
  • 数据传递流程

    • 生产者消费者模式,即N个线程进行生产,同时N个线程进行消费,两种角色通过内存缓冲区进行通信。
    • 生产者负责向缓冲区里面添加数据单元
    • 消费者负责从缓冲区里面取出数据单元
      • 一般遵循先进先出的原则
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值