RabbitMq和Kafka架构异同分析:

rabbitmq:

  1. 架构为生产者-交换机-队列-消费者
  2. 交换机和队列之间通过路由键绑定,即routing key
  3. 消费者通过直接监听队列消费消息
  4. 交换机有四种类型,分别是faount广播交换机,会将消息发给下面所有队列;topic交换机,可以通过模糊匹配rk路由键,将消息转发到指定的队列中;direct交换机,通过完全匹配rk路由键,将消息转发到指定的队列中;header交换机使用的较少

kafka:

  1. 架构为生产者-broker-topic-partition-消费者组-消费者
  2. 消费者绑定在消费者组中,监听topic消费消息
  3. topic的消息只会被同一个消费者组中的一个消费者消费,所以消费者组中的消费者都会指定需要消费的topic中的partition
  4. 消息基本都是基于发布-订阅模式的

消息重复消费问题:

分布式集群下:

在RabbitMq中,消费者通过监听队列消费消息,当出现读个消费者监听同一个队列的情况时,RabbitMq中的轮询机制会保证消息只会被一个消费者消费

在Kafka中,消息是基于消费者组被订阅的,消费者组中的一个消费者只会消费一个topic中的一个partition的消息,也保证了消息只会被一个消费者消费

相关推荐
ApachePulsar20 小时前
演讲回顾|谙流科技在 Kafka on Pulsar 之上的探索
分布式·科技·kafka
怦怦蓝20 小时前
DB2深度解析:从架构原理到与R语言的集成实践
开发语言·架构·r语言·db2
ujainu1 天前
Flutter + OpenHarmony 游戏开发进阶:主菜单架构与历史最高分持久化
flutter·游戏·架构·openharmony
qq_312920111 天前
Nginx+Keepalived双主架构:消除单点故障的最佳实践
运维·nginx·架构
yumgpkpm1 天前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
Jia ming1 天前
内存架构解析:UMA与NUMA对比
架构
爱内卷的学霸一枚1 天前
现代微服务架构实践:从设计到部署的深度解析
windows·微服务·架构
迎仔2 天前
13-云原生大数据架构介绍:大数据世界的“弹性城市”
大数据·云原生·架构
ALex_zry2 天前
分布式缓存与微服务架构的集成
分布式·缓存·架构
贾修行2 天前
企业级网络安全架构实战:从防火墙部署到远程办公全解析
web安全·架构·智能路由器