问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
你好,欢迎来到懂视!登录注册
当前位置: 首页 - 正文

rabbitmq与kafka到底用哪个好

发布网友 发布时间:2022-03-26 08:21

我来回答

3个回答

懂视网 时间:2022-03-26 12:43

rabbitmq的工作模式有:

  1、简单模式:一个生产者,一个消费者。

  

  2、work模式:一个生产者,多个消费者,每个消费者获取到的消息唯一。

  

  3、订阅模式:一个生产者发送的消息会被多个消费者获取。

  

  4、路由模式:发送消息到交换机并且要指定路由key ,消费者将队列绑定到交换机时需要指定路由key。

  

  5、topic模式:将路由键和某模式进行匹配,此时队列需要绑定在一个模式上,“#”匹配一个词或多个词,“*”只匹配一个词。

  

  6、heard模式:和Routing模式的不同就是取消了routing 使用键值对的方式作为routing。

  MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。其中较为成熟的MQ产品有IBM WEBSPHERE MQ等等。

热心网友 时间:2022-03-26 09:51

Kafka和RabbitMq一样是通用意图消息代理,他们都是以分布式部署为目的。但是他们对消息语义模型的定义的假设是非常不同的。我对"AMQP 更成熟"这个论点是持怀疑态度的。让我们用事实说话来看看用什么解决方案来解决你的问题。
a) 以下场景你比较适合使用Kafka。你有大量的事件(10万以上/秒)、你需要以分区的,顺序的,至少传递成功一次到混杂了在线和打包消费的消费者、你希望能重读消息、你能接受目前是有限的节点级别高可用或则说你并不介意通过论坛/IRC工具得到还在幼儿阶段的软件的支持。
b) 以下场景你比较适合使用RabbitMQ。你有较少的事件(2万以上/秒)并且需要通过复杂的路由逻辑去找到消费者、你希望消息传递是可靠的、你并不关心消息传递的顺序、你需要现在就支持集群-节点级别的高可用或则说你需要7*24小时的付费支持(当然也可以通过论坛/IRC工具)。

热心网友 时间:2022-03-26 11:09

付费内容限时免费查看回答这篇文章会先介绍一下基本的异步消息模式,然后再介绍一下RabbitMQ和Kafka以及他们的内部结构信息。第二部分(未完成)主要介绍这两种技术的主要不同点以及他们各自的优缺点,最后我们会说明一下怎样选择这两种技术。

异步消息模式

异步消息可以作为解耦消息的生产和处理的一种解决方案。提到消息系统,我们通常会想到两种主要的消息模式——消息队列和发布/订阅模式。

消息队列

利用消息队列可以解耦生产者和消费者。多个生产者可以向同一个消息队列发送消息;但是,一个消息在被一个消息者处理的时候,这个消息在队列上会被锁住或者被移除并且其他消费者无法处理该消息。也就是说一个具体的消息只能由一个消费者消费。

消息队列

需要额外注意的是,如果消费者处理一个消息失败了,消息系统一般会把这个消息放回队列,这样其他消费者可以继续处理。消息队列除了提供解耦功能之外,它还能够对生产者和消费者进行独立的伸缩(scale),以及提供对错误处理的容错能力。

发布/订阅

发布/订阅(pub/sub)模式中,单个消息可以被多个订阅者并发的获取和处理。

发布/订阅

例如,一个系统中产生的事件可以通过这种模式让发布者通知所有订阅者。在许多队列系统中常常用主题(topics)这个术语指代发布/订阅模式。在RabbitMQ中,主题就是发布/订阅模式的一种具体实现(更准确点说是交换器(exchange)的一种),但是在这篇文章中,我会把主题和发布/订阅当做等价来看待。

一般来说,订阅有两种类型:

临时(ephemeral)订阅,这种订阅只有在消费者启动并且运行的时候才存在。一旦消费者退出,相应的订阅以及尚未处理的消息就会丢失。

持久(rable)订阅,这种订阅会一直存在,除非主动去删除。消费者退出后,消息系统会继续维护该订阅,并且后续消息可以被继续处理。

RabbitMQ

RabbitMQ作为消息中间件的一种实现,常常被当作一种服务总线来使用。RabbitMQ原生就支持上面提到的两种消息模式。其他一些流行的消息中间件的实现有ActiveMQ,ZeroMQ,Azure Service Bus以及Amazon Simple Queue Service(SQS)。这些消息中间件的实现有许多共通的地方;这边文章中提到的许多概念大部分都适用于这些中间件。

队列

RabbitMQ支持典型的开箱即用的消息队列。开发者可以定义一个命名队列,然后发布者可以向这个命名队列中发送消息。最后消费者可以通过这个命名队列获取待处理的消息。

消息交换器

RabbitMQ使用消息交换器来实现发布/订阅模式。发布者可以把消息发布到消息交换器上而不用知道这些消息都有哪些订阅者。

每一个订阅了交换器的消费者都会创建一个队列;然后消息交换器会把生产的消息放入队列以供消费者消费。消息交换器也可以基于各种路由规则为一些订阅者过滤消息。

RabbitMQ消息交换器

需要重点注意的是RabbitMQ支持临时和持久两种订阅类型。消费者可以调用RabbitMQ的API来选择他们想要的订阅类型。

根据RabbitMQ的架构设计,我们也可以创建一种混合方法——订阅者以组队的方式然后在组内以竞争关系作为消费者去处理某个具体队列上的消息,这种由订阅者构成的组我们称为消费者组。按照这种方式,我们实现了发布/订阅模式,同时也能够很好的伸缩(scale-up)订阅者去处理收到的消息。

发布/订阅与队列的联合使用

Apache Kafka

Apache Kafka不是消息中间件的一种实现。相反,它只是一种分布式流式系统。

不同于基于队列和交换器的RabbitMQ,Kafka的存储层是使用分区事务日志来实现的。Kafka也提供流式API用于实时的流处理以及连接器API用来更容易的和各种数据源集成;当然,这些已经超出了本篇文章的讨论范围。

云厂商为Kafka存储层提供了可选的方案,比如Azure Event Hubsy以及AWS Kinesis Data Streams等。对于Kafka流式处理能力,还有一些特定的云方案和开源方案,不过,话说回来,它们也超出了本篇的范围。

主题

Kafka没有实现队列这种东西。相应的,Kafka按照类别存储记录集,并且把这种类别称为主题。

Kafka为每个主题维护一个消息分区日志。每个分区都是由有序的不可变的记录序列组成,并且消息都是连续的被追加在尾部。

当消息到达时,Kafka就会把他们追加到分区尾部。默认情况下,Kafka使用轮询分区器(partitioner)把消息一致的分配到多个分区上。

Kafka可以改变创建消息逻辑流的行为。例如,在一个多租户的应用中,我们可以根据每个消息中的租户ID创建消息流。IoT场景中,我们可以在常数级别下根据生产者的身份信息(identity)将其映射到一个具体的分区上。确保来自相同逻辑流上的消息映射到相同分区上,这就保证了消息能够按照顺序提供给消费者。

Kafka生产者

消费者通过维护分区的偏移(或者说索引)来顺序的读出消息,然后消费消息。

单个消费者可以消费多个不同的主题,并且消费者的数量可以伸缩到可获取的最大分区数量。

所以在创建主题的时候,我们要认真的考虑一下在创建的主题上预期的消息吞吐量。消费同一个主题的多个消费者构成的组称为消费者组。通过Kafka提供的API可以处理同一消费者组中多个消费者之间的分区平衡以及消费者当前分区偏移的存储。

值得特别注意的是,Kafka是按照预先配置好的时间保留分区中的消息,而不是根据消费者是否消费了这些消息。这种保留机制可以让消费者自由的重读之前的消息。另外,开发者也可以利用Kafka的存储层来

kafka和mq的区别

2、rabbitMQ在吞吐量方面稍逊于kafka,它们的出发点不一样,rabbitMQ支持对消息的可靠的传递,支持事务,不支持批量的操作。基于存储的可靠性的要求存储可以采用内存或者硬盘。kafka具有高的吞吐量,内部采用消息的批量处理,zerocopy机制,数据的存储和获取是本地磁盘顺序批量操作,具有O的复杂度,消息处理...

消息队列黄金三剑客:RabbitMQ、RocketMQ和Kafka全面对决,谁是最佳选择...

消息队列的选择往往取决于特定的应用需求和场景。以下是RabbitMQ、RocketMQ和Kafka的对比分析:RabbitMQ,以其易用性和灵活性闻名,适用于对操作简便和快速响应时间有较高要求的场景。它自带的Web管理界面直观易用,允许用户监控和管理队列、交换机等关键组件。相比之下,RocketMQ专为大规模数据处理和高吞吐...

rabbitmq和kafka的区别

1、消息协议:RabbitMQ使用AMQP(高级消息队列协议),而Kafka使用其自定义的协议。AMQP是一种标准协议,可以提供更强的互操作性,但Kafka的自定义协议可能具有更高的性能。2、消息格式:RabbitMQ支持多种消息格式,如JSON、XML等,而Kafka只支持二进制格式。这使得RabbitMQ在处理复杂消息时更为灵活。3、...

Kafka、ActiveMQ、RabbitMQ、RocketMQ 都有什么优点和缺点?

Kafka、ActiveMQ、RabbitMQ、RocketMQ 都是流行的消息队列中间件,它们各有优缺点。以下是一些总结和区别:- Kafka:高吞吐量、低延迟、高可用性、分布式、持久化存储、多租户支持等 。- ActiveMQ:支持JMS1.1和J2EE 1.4规范,具有良好的面向企业级应用程序的特性,如负载均衡、可靠性、安全性等 。- ...

kafka、activemq、rabbitmq、rocketmq都有什么优点和缺点

Kafka解决消息重复消费问题通过消息唯一性标记、消费者组的管理和消息的精确一次性(Exactly Once)投递策略。Kafka的解决方案侧重于提供高效、可靠且可扩展的消息传递服务,确保消息消费的顺序性和唯一性。消息顺序性在RabbitMQ中依赖于交换器和队列的配置、消息路由策略以及消息发布顺序。RabbitMQ提供多种交换...

4 种消息队列,如何选型?

选型建议Kafka适合大量数据生成的互联网服务,尤其是日志收集;RocketMQ在金融场景中的高可靠性是其优势,适合订单处理等高并发场景;RabbitMQ性能好且社区活跃,适合小规模且对功能需求全面的项目。总体而言,根据业务需求和性能要求,选择最适合的队列技术是关键,ActiveMQ在大规模吞吐场景中的选择相对有限。

Redis、Kafka或RabbitMQ:哪个作为微服务消息代理最合适?

Kafka是一个高吞吐量的分布式队列,用于长时间存储大量数据。对于需要持久性的一对多用例,Kafka是理想的选择。复杂路由:RabbitMQ RabbitMQ是一个较老但很成熟的代理,具有许多支持复杂路由的功能。当所需速率不高(超过数万msg sec)时,它甚至将支持复杂的路由通信。考虑您的软件堆栈 当然,最后要考虑的...

消息队列之zeroMQ、rabbitMQ、kafka

kafka 也是分布式的,一个数据多个副本,少数机器宕机,不会丢失数据,不会导致不可用 时效性 RabbitMQ 基于erlang开发,所以并发能力很强,性能极其好,延时很低,达到微秒级。其他两个个都是 ms 级。 功能支持 Kafka 功能较为简单,主要支持简单的MQ功能,在大数据领域实时计算以及日志采集被大规模使用;ZeroMQ能够 实现...

消息中间件(MQ)的技术选型(Kafka、RabbitMQ、RocketMQ)

优点: RocketMQ几乎同时解决了Kafka和RabbitMQ的缺陷。它的吞吐量也非常高,单机可以达到10万的QPS以上,而且可以保证高可用性,并且可以通过配置达到数据保证不会丢失,可以部署大规模的集群,还支持各种高级功能,比如说延迟消息、事务消息、消息回溯、死信队列、消息积压等。而且RocketMQ是利用java开发的...

kafka不适合场景

Kafka不适合的场景有小规模应用、延迟敏感的应用程序等。如果您的应用程序规模较小且只有少量的消息传递需求,那么Kafka可能过于复杂和冗余。在这种情况下,您可以选择更简单的消息队列解决方案,如RabbitMQ或者直接使用数据库进行消息传递。Kafka是一种持久化的消息传递系统,为了保证可靠性和一致性,可能会...

声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。
E-MAIL:11247931@qq.com
为什么网上有那么多贝婴邦,到底哪个是真的啊? 电饭煲哪个是小火 新手怎样种植睫毛? 阿维菌素使用方法 阿维菌素的作用和使用方法是什么?怎 这个账号密码是什么?路由器密码也不对,宽带密码也不对 拼多多拒收退回快递怎么操作 高通与谷歌合作的Android Things物联网系统明年对所有骁龙处理器开放... 艾滋病中医能治疗吗 中药用于艾滋病的效果 rabbitmq和kafka的区别 Rabbitmq 和 Celery 是怎样工作的 rabbitmq一共有几种模式 大家觉得华为荣耀9青春版怎么样 华为荣耀9青春版怎么样 华为荣耀9和9青春版哪个好 华为荣耀和华为荣耀青春版有什么区别 华为Nova青春版和华为 荣耀9有什么区别 华为荣耀9青春版怎么样? 华为荣耀9青春版多少钱 华为荣耀9青春版配置一览 华为荣耀和华为荣耀青春版有什么区别? 荣耀9和荣耀9青春版的区别 华为荣耀9青春版参数配置? 华为荣耀9和荣耀9青春版有什么区别???? honor9lite是什么手机 Honor 9 Lite 是全网通吗 华为荣耀9青春版? honor 9 lite什么型号 荣耀9LITE是荣耀9青春吗 honor9lite是什么手机,什么青春版还有i 还有荣耀九v 那个lite到底是哪个,一直搞不清 rabbitmq的镜像集群模式如何实现线性扩容? RabbitMQ怎样能实现多个队列由一个消费者来接收消息 rabbit消息队列是推还是拉模式 net redis 和rabbitmq 有什么区别 rabbitmq可以支持多少个消费者同时监听 分布式、中间件和消息队列到底是怎么的一种工作模式? rabbitmq保证消息不丢失? 我为什么要选择RabbitMQ 请问kafka和rabbitmq有啥区别啊? rabbitmq中,使用一个exchange和使用多个exchange,性能会有差别吗 rabbitmq 怎么设置集群发送 ip zookeeper与rabbitmq有什么不同 rabbitmq使用haproxy哪个算法 kafkaMQ,rabbitMQ怎么选择 如何重启宽带路由器? 如何重启电脑上的路由器和光猫? 路由器没有复位开关,那怎么复位 光猫路由器怎么重启 华为荣耀路由器怎么重启 路由器没有开关,如何重启
  • 焦点

最新推荐

猜你喜欢

热门推荐