广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >RabbitMQ和Kafka有什么不同
  • 145
分享到

RabbitMQ和Kafka有什么不同

2024-04-02 19:04:59 145人浏览 安东尼
摘要

这篇文章主要讲解了“RabbitMQ和kafka有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ和Kafka有什么不同”吧! #

这篇文章主要讲解了“RabbitMQkafka有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ和Kafka有什么不同”吧!

# RabbitMQ架构

## 概念

RabbitMQ是一个分布式系统

**broker**:每个节点运行的服务程序,功能为维护该节点的队列的增删以及转发队列操作请求。

**master queue**:每个队列都分为一个主队列和若干个镜像队列。

**mirror queue**:镜像队列,作为master queue的备份。在master queue所在节点挂掉之后,系统把mirror queue提升为master queue,负责处理客户端队列操作请求。注意,mirror queue只做镜像,设计目的不是为了承担客户端读写压力。

RabbitMQ和Kafka有什么不同

如上图所示,集群中有两个节点,每个节点上有一个broker,每个broker负责本机上队列的维护,并且borker之间可以互相通信。集群中有两个队列A和B,每个队列都分为master queue和mirror queue(备份)。那么队列上的生产消费怎么实现的呢?

## 队列消费

RabbitMQ和Kafka有什么不同

如上图有两个consumer消费队列A,这两个consumer连在了集群的不同机器上。RabbitMQ集群中的任何一个节点都拥有集群上所有队列的元信息,所以连接到集群中的任何一个节点都可以,主要区别在于有的consumer连在master queue所在节点,有的连在非master queue节点上。 因为mirror queue要和master queue保持一致,故需要同步机制,正因为一致性的限制,导致所有的读写操作都必须都操作在master queue上(想想,为啥读也要从master queue中读?和数据库读写分离是不一样的。),然后由master节点同步操作到mirror queue所在的节点。即使consumer连接到了非master queue节点,该consumer的操作也会被路由到master queue所在的节点上,这样才能进行消费。

## 队列生产

RabbitMQ和Kafka有什么不同

原理和消费一样,如果连接到非 master queue 节点,则路由过去。

**不足** 由于master queue单节点,导致性能瓶颈,吞吐量受限。虽然为了提高性能,内部使用了Erlang这个语言实现,但是终究摆脱不了架构设计上的致命缺陷。

# Kafka

说实话,Kafka我觉得就是看到了RabbitMQ这个缺陷才设计出的一个改进版,改进的点就是:把一个队列的单一master变成多个master,即一台机器扛不住qps,那么我就用多台机器扛qps,把一个队列的流量均匀分散在多台机器上不就可以了么?注意,多个master之间的数据没有交集,即一条消息要么发送到这个master queue,要么发送到另外一个master queue。 这里面的每个master queue 在Kafka中叫做Partition,即一个分片。一个队列有多个主分片,每个主分片又有若干副分片做备份,同步机制类似于RabbitMQ。

RabbitMQ和Kafka有什么不同

如上图,我们省略了不同的queue,假设集群上只有一个queue(Kafka中叫Topic)。每个生产者随机把消息发送到主分片上,之后主分片再同步给副分片。

RabbitMQ和Kafka有什么不同

队列读取的时候虚拟出一个Group的概念,一个Topic内部的消息,只会路由到同Group内的一个consumer上,同一个Group中的consumer消费的消息是不一样的;Group之间共享一个Topic,看起来就是一个队列的多个拷贝。所以,为了达到多个Group共享一个Topic数据,Kafka并不会像RabbitMQ那样消息消费完毕立马删除,而是必须在后台配置保存日期,即只保存最近一段时间的消息,超过这个时间的消息就会从磁盘删除,这样就保证了在一个时间段内,Topic数据对所有Group可见(这个特性使得Kafka非常适合做一个公司的数据总线)。队列读同样是读主分片,并且为了优化性能,消费者与主分片有一一的对应关系,如果消费者数目大于分片数,则存在某些消费者得不到消息。 由此可见,Kafka绝对是为了高吞吐量设计的,比如设置分片数为100,那么就有100台机器去扛一个Topic的流量,当然比RabbitMQ的单机性能好。

感谢各位的阅读,以上就是“RabbitMQ和Kafka有什么不同”的内容了,经过本文的学习后,相信大家对RabbitMQ和Kafka有什么不同这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: RabbitMQ和Kafka有什么不同

本文链接: https://www.lsjlt.com/news/93654.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • RabbitMQ和Kafka有什么不同
    这篇文章主要讲解了“RabbitMQ和Kafka有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ和Kafka有什么不同”吧! # ...
    99+
    2022-10-19
  • kafka同步发送和异步发送有什么区别
    Kafka的同步发送和异步发送是两种不同的消息发送方式。1. 同步发送:同步发送是指发送方发送一条消息后,会立即等待服务器的响应。只...
    99+
    2023-10-12
    kafka
  • Java和C#有什么不同
    小编给大家分享一下Java和C#有什么不同,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Java和C#都提供了对网络的不同抽象层,编程人员可以使用不同的网络接口完...
    99+
    2023-06-03
  • ajax和javascript有什么不同
    这篇文章给大家介绍ajax和javascript有什么不同,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JavaScript的特点1.JavaScript主要用来向HTML页面添加交互行为。2.JavaScript可以...
    99+
    2023-06-14
  • C#和C++有什么不同
    本篇内容介绍了“C#和C++有什么不同”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在C语言中,资源管理是一个极为繁琐易错的工作,大多复杂的...
    99+
    2023-06-18
  • HashMap和Hashtable有什么不同
    HashMap和Hashtable有什么不同,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。线程安全两者最主要的区别在于Hashtable是线程安全,而HashM...
    99+
    2023-06-19
  • service和systemctl有什么不同
    这篇文章主要介绍了service和systemctl有什么不同的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇service和systemctl有什么不同文章都会有所收获,下面我们一起来看看吧。service命令...
    99+
    2023-06-27
  • DevOps和SRE有什么不同
    一、概念不同 DevOps是一种将开发和运维团队紧密集成在一起的实践方法,旨在提高软件开发和交付的效率和质量。DevOps强调自动化、持续集成和部署、监控和反馈等方面,以实现快速、可靠和可重复的软件开发和交付。 SRE(Site Relia...
    99+
    2023-10-29
    有什么不同 DevOps SRE
  • relative和absolute有什么不同
    本文小编为大家详细介绍“relative和absolute有什么不同”,内容详细,步骤清晰,细节处理妥当,希望这篇“relative和absolute有什么不同”文章能帮助大家解决疑惑,下面跟着小编的思路慢...
    99+
    2022-10-19
  • Java和JavaScript:有什么不同?
    Java和JavaScript这两个名字看似相似,但实际上它们是完全不同的编程语言。在本文中,我们将探讨Java和JavaScript的不同之处。 Java和JavaScript的起源 Java是由Sun Microsystems公司...
    99+
    2023-09-10
    javascript shell linux
  • Ubuntu和Fedora有什么不同
    本篇内容主要讲解“Ubuntu和Fedora有什么不同”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Ubuntu和Fedora有什么不同”吧!桌面概述Fedora提供了vanilla GNOME...
    99+
    2023-06-27
  • Java 和 JavaScript 有什么不同?
    Java 和 JavaScript 是两种编程语言,它们有着不同的用途和特点。本文将深入探讨 Java 和 JavaScript 的不同之处,帮助你更好地理解这两种语言。 Java 是一种面向对象的编程语言,最初由 Sun Microsys...
    99+
    2023-06-28
    文件 javascript numpy
  • Python3和Python2有什么不同
    今天就跟大家聊聊有关Python3和Python2有什么不同,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、打印时,py2需要可以不需要加括号,py3 需要python 2 :pr...
    99+
    2023-06-15
  • 【RabbitMQ】什么是RabbitMQ?RabbitMQ有什么用?应用场景有那些?
    目录 一、什么是RabbitMQ? 二、RabbitMQ是干什么的? 三、RabbitMQ的常见作用有那些? 四、RabbitMQ的应用场景有那些? 场景一:用户订单,库存处理。【服务间解耦】 场景二:用户注册,发送手机短信,邮件。【实现异...
    99+
    2023-08-31
    rabbitmq java 中间件 MQ
  • Java和JavaScript有什么相同点和不同点?
    Java和JavaScript是两种非常常见的编程语言,它们在开发应用程序和网站方面都有着广泛的应用。虽然它们的名字很相似,但它们有着不同的用途和特点。本文将探讨Java和JavaScript之间的相同点和不同点。 一、相同点 编程语言 ...
    99+
    2023-08-26
    javascript 数据类型 关键字
  • RabbitMQ,RocketMQ,Kafka事务性的处理策略是什么
    这篇文章主要讲解了“RabbitMQ,RocketMQ,Kafka事务性的处理策略是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ,RocketMQ,Kafka事务性的处...
    99+
    2023-06-29
  • abstract class和interface有什么不同
    这篇文章主要讲解了“abstract class和interface有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“abstract class和interface有什么不同”吧!我...
    99+
    2023-06-17
  • php socket和curl有什么不同
    本文操作环境:Windows7系统、PHP7.1版、DELL G3电脑php socket和curl有什么不同?php的curl和socket的区别首先说下啥是socket:PHP使用berkely的socket库来创建他的连接,socke...
    99+
    2015-11-29
    php socket curl
  • Manjaro和Arch Linux有什么不同
    这篇文章主要讲解了“Manjaro和Arch Linux有什么不同”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Manjaro和Arch Linux有什么不同”吧!Manjaro 和 Arc...
    99+
    2023-06-15
  • Spring boot和Spring有什么不同
    这篇文章将为大家详细讲解有关Spring boot和Spring有什么不同,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Spring Boot 简介spring框架功能很强大,但是就算是一个...
    99+
    2023-05-31
    spring spring boot spring boo
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作