返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎么从0到1设计一个MQ消息队列
  • 395
分享到

怎么从0到1设计一个MQ消息队列

2024-04-02 19:04:59 395人浏览 独家记忆
摘要

本篇内容主要讲解“怎么从0到1设计一个MQ消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从0到1设计一个MQ消息队列”吧!消息队列整体设计思路主要是

本篇内容主要讲解“怎么从0到1设计一个MQ消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从0到1设计一个MQ消息队列”吧!

消息队列整体设计思路

主要是设计一个整体的消息被消费的数据流。

这里会涉及到:消息生产Producer、Broker(消息服务端)、消息消费者Consumer。

怎么从0到1设计一个MQ消息队列

1.Producer(消息生产者):发送消息到Broker。

2.Broker(服务端):Broker这个概念主要来自于Apache的ActiveMQ,特指消息队列的服务端。

主要功能就是:把消息从发送端传送到接收端,这里会涉及到消息的存储、消息通讯机制等。

3.Consumer(消息消费者):从消息队列接收消息,consumer回复消费确认。

Broker(消息队列服务端)设计重点

1)消息的转储:在更合适的时间点投递,或者通过一系列手段辅助消息最终能送达消费机。

2)规范一种范式和通用的模式,以满足解耦、最终一致性、错峰等需求。

3)其实简单理解就是一个消息转发器,把一次rpc做成两次RPC,发送者把消息投递到broker,broker再将消息转发一手到接收端。

总结起来就是两次RPC加一次转储,如果要做消费确认,则是三次RPC。

为了实现上述消息队列的基础功能:

1)消息的传输

2)存储

3)消费

就需要涉及到如下三个方面的设计:

1)通信协议

2)存储选择

3)消费关系维护

通讯协议

消息Message:  既是信息的载体,消息发送者需要知道如何构造消息,消息接收者需要知道如何解析消息,它们需要按照一种统一的格式描述消息,这种统一的格式称之为消息协议。

传统的通信协议标准有XMPP和AMQP协议等,现在更多的消息队列从性能的角度出发使用自己设计实现的通信协议。

1.JMS

JMS(Java MessageService)实际上是指JMS  api。JMS是由Sun公司早期提出的消息标准,旨在为java应用提供统一的消息操作,包括创建消息、发送消息、接收消息等。

JMS通常包含如下一些角色:

怎么从0到1设计一个MQ消息队列

JMS提供了两种消息模型:

1)点对点

2)以及publish-subscribe(发布订阅)模型。

当采用点对点模型时,消息将发送到一个队列,该队列的消息只能被一个消费者消费。

怎么从0到1设计一个MQ消息队列

而采用发布订阅模型时,消息可以被多个消费者消费。

在发布订阅模型中,生产者和消费者完全独立,不需要感知对方的存在。

2.AMQP

AMQP是 Advanced Message Queuing Protocol,即高级消息队列协议。

AMQP不是一个具体的消息队列实现,而 是一个标准化的消息中间件协议。

目标是让不同语言,不同系统的应用互相通信,并提供一个简单统一的模型和编程接口。 目前主流的ActiveMQ和RabbitMQ都支持AMQP协议。

AMQP是一种协议,更准确的说是一种binary wire-level  protocol(链接协议)。这是其和JMS的本质差别,AMQP不从API层进行限定,而是直接定义网络交换的数据格式。

JMS和AMQP比较

JMS: 只允许基于JAVA实现的消息平台的之间进行通信

AMQP: AMQP允许多种技术同时进行协议通信

3.Kafka的通信协议

kafka的Producer、Broker和Consumer之间采用的是一套自行设计的基于tcp层的协议。Kafka的这套协议完全是为了Kafka自身的业务需求而定制的。

存储选型

对于分布式系统,存储的选择有以下几种

1.内存

2.本地文件系统

3.分布式文件系统

4.NoSQL

5.DB

从速度上内存显然是最快的,对于允许消息丢失,消息堆积能力要求不高的场景(例如日志),内存会是比较好的选择。

DB则是最简单的实现可靠存储的方案,很适合用在可靠性要求很高,最终一致性的场景(例如交易消息),对于不需要100%保证数据完整性的场景,要求性能和消息堆积的场景,HBase也是一个很好的选择。

理论上,从速度来看,文件系统>分布式KV(持久化)>分布式文件系统>数据库,而可靠性却截然相反。

还是要从支持的业务场景出发作出最合理的选择,如果你们的消息队列是用来支持支付/交易等对可靠性要求非常高,但对性能和量的要求没有这么高,而且没有时间精力专门做文件存储系统的研究,DB是最好的选择。

对于不需要100%保证数据完整性的场景,要求性能和消息堆积的场景,hbase也是一个很好的选择,典型的比如  kafka的消息落地可以使用hadoop

消费关系处理

现在我们的消息队列初步具备了转储消息的能力。

下面一个重要的事情就是解析发送接收关系,进行正确的消息投递了。

市面上的消息队列定义了一堆让人晕头转向的名词,如JMS  规范中的Topic/Queue,Kafka里面的Topic/Partition/ConsumerGroup,RabbitMQ里面的Exchange等等。

抛开现象看本质,无外乎是单播与广播的区别。

所谓单播,就是点到点;而广播,是一点对多点。

为了实现广播功能,我们必须要维护消费关系,通常消息队列本身不维护消费订阅关系,可以利用ZooKeeper等成熟的系统维护消费关系,在消费关系发生变化时下发通知。

消息队列需要支持高级特性

  • 消息的顺序

  • 投递可靠性保证

  • 消息持久化

  • 支持不同消息模型

  • 多实例集群功能

  • 事务特性等

除了上述的消息队列基本功能以外,消息队列在某些特殊的场景还需要支持事务,消息重试等功能。

到此,相信大家对“怎么从0到1设计一个MQ消息队列”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 怎么从0到1设计一个MQ消息队列

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

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

猜你喜欢
  • 怎么从0到1设计一个MQ消息队列
    本篇内容主要讲解“怎么从0到1设计一个MQ消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从0到1设计一个MQ消息队列”吧!消息队列整体设计思路主要是...
    99+
    2024-04-02
  • MQ消息队列怎么用
    本篇内容介绍了“MQ消息队列怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!消息生产失败一般来说,从生...
    99+
    2024-04-02
  • MQ消息队列中间件RabbitMQ怎么用
    小编给大家分享一下MQ消息队列中间件RabbitMQ怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MQ消息队列中间件—RabbitMQ消息中间件主要用于组件...
    99+
    2023-06-04
  • 手把手教你用redis实现一个简单的mq消息队列(java)
      众所周知,消息队列是应用系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实现高性能,高可用,可伸缩和最终一致性架构。目前使用较多的消息队列有 ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,Ro...
    99+
    2017-12-15
    手把手教你用redis实现一个简单的mq消息队列(java)
  • 利用Redis流怎么实现一个消息队列
    利用Redis流怎么实现一个消息队列?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。代码清单 10-1 展示了一个具有基本功能的消息队列实现:代...
    99+
    2024-04-02
  • 下一代消息队列Pulsar到底是什么
    Pulsar是一种下一代的分布式消息队列系统。它由Apache软件基金会开发和维护,旨在提供高可用性、可扩展性和灵活性的消息传递解决...
    99+
    2023-09-22
    Pulsar
  • java开发微服务架构怎么设计消息队列
    本篇内容介绍了“java开发微服务架构怎么设计消息队列”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!消息队列的作用在微服务开发中我们经常会引...
    99+
    2023-06-25
  • 如何设计一个可靠的MySQL表结构来实现消息队列功能?
    如何设计一个可靠的MySQL表结构来实现消息队列功能?摘要:消息队列是现代软件系统中常用的一种通信机制,用于解耦和提高系统的可靠性。MySQL是一个强大的关系型数据库管理系统,可以用来实现消息队列功能。本文将介绍如何设计一个可靠的MySQL...
    99+
    2023-10-31
    消息队列 关键词:MySQL 表结构
  • tp5缓存设置为redis怎么做消息队列
    tp5缓存设置为redis做消息队列的示例:根据选择的存储方式,在\application\extra\queue.php这个配置文件中,添加消息队列对应的驱动配置,例如:return ['connector' => 'Redis', //...
    99+
    2024-04-02
  • 怎么从0到1部署一套TiDB本地集群
    这篇文章主要讲解了“怎么从0到1部署一套TiDB本地集群”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么从0到1部署一套TiDB本地集群”吧!TiDB是一...
    99+
    2024-04-02
  • 怎么使用django+celery+RabbitMQ自定义多个消息队列
    本篇内容主要讲解“怎么使用django+celery+RabbitMQ自定义多个消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用django+celery+RabbitMQ自定义多...
    99+
    2023-07-05
  • RabbitMQ是怎么确定消息是否投递到队列中的
    本篇内容介绍了“RabbitMQ是怎么确定消息是否投递到队列中的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
  • MySQL特定表全量、增量数据同步到消息队列怎么实现
    本篇内容主要讲解“MySQL特定表全量、增量数据同步到消息队列怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL特定表全量、增量数据同步到消息队列怎么实现”吧!1、原始需求既要同步...
    99+
    2023-06-21
  • 企业级分布式消息系统设计与实现:如何设计和实现一个完整的企业级分布式消息系统,包含消息队列、代理服务器、存储服务器等不同层面的技术细节
    作者:禅与计算机程序设计艺术 1.简介 在分布式系统中,消息队列(Message Queue)是一种用于进程间通信或跨网络传递异步消息的技术。基于消息队列的分布式系统可以帮助用户解决复杂的并行计算问题...
    99+
    2023-10-10
    自然语言处理 人工智能 语言模型 编程实践 开发语言 架构设计
  • Android项目中怎么设计一个UI手机信息页面
    今天就跟大家聊聊有关Android项目中怎么设计一个UI手机信息页面,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 设计思路(实现原理) 将准备好的八个图标复制到...
    99+
    2023-05-31
    android roi 目中
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作