0
点赞
收藏
分享

微信扫一扫

分布式消息队列RocketMQ

343d85639154 2022-03-30 阅读 100
java

第1章 RocketMQ概述

一、  MQ概述

1、 MQ简介

MQ Message Queue,是一种提供 消息队列服务 的中间件,也称为消息中间件,是一套提供了消息生 产、存储、消费全过程API的软件系统。消息即数据。一般消息的体量不会很大。

2、  MQ用途

从网上可以查看到很多的关于MQ用途的叙述,但总结起来其实就以下三点。

限流削峰

MQ可以将系统的 超量 请求暂存其中,以便系统后期可以慢慢进行处理,从而避免了请求的丢失或系统 被压垮。

 

异步解耦       

上游系统对下游系统的调用若为同步调用,则会大大降低系统的吞吐量与并发度,且系统耦合度太高。 而异步调用则会解决这些问题。所以两层之间若要实现由同步到异步的转化,一般性做法就是,在这两 层间添加一个MQ层。

 

数据收集                                                                                                                                       

分布式系统会产生海量级数据流,如:业务日志、监控数据、用户行为等。针对这些数据流进行实时或 批量采集汇总,然后对这些数据流进行大数据分析,这是当前互联网平台的必备技术。通过MQ完成此  类数据收集是最好的选择。

3、  常见MQ产品

ActiveMQ

ActiveMQ是使用Java语言开发一款MQ产品。  早期很多公司与项目中都在使用。但现在的社区活跃度已 经很低。现在的项目中已经很少使用了。

RabbitMQ                                                                                                                                    

RabbitMQ是使用ErLang语言开发的一款MQ产品。其吞吐量较KafkaRocketMQ要低,且由于其不是 Java语言开发,所以公司内部对其实现定制化开发难度较大。

Kafka                                                                                                                                           

Kafka是使用Scala/Java语言开发的一款MQ产品。其最大的特点就是高吞吐率,常用于大数据领域的实

时计算、日志采集等场景。其没有遵循任何常见的MQ协议,而是使用自研协议。对于Spring Cloud Netçix,其仅支持RabbitMQKafka

RocketMQ

RocketMQ是使用Java语言开发的一款MQ产品。经过数年阿里双11的考验,性能与稳定性非常高。其 没有遵循任何常见的MQ协议,而是使用自研协议。对于Spring Cloud Alibaba,其支持RabbitMQ   Kafka,但提倡使用RocketMQ

对比    

关键词     ACTIVEMQ  RABBITMQ                 KAFKA                             ROCKETMQ

开发语言         Java            ErLang                          Java                                         Java

单机吞吐量         万级             万级                        十万级                                   十万级

Topic                ——          ——               百级Topic时会影响系统吞吐     千级Topic时会影响系统吞吐

社区活跃度        低                高                                高                                        高

        

4、  MQ常见协议

一般情况下MQ的实现是要遵循一些常规性协议的。常见的协议如下:

JMS

JMS Java Messaging ServiceJava消息服务)。是Java平台上有关MOMMessage Oriented            Middleware,面向消息的中间件 PO/OO/AO)的技术规范,它便于消息系统中的Java应用程序进行消  息交换,并且通过提供标准的产生、发送、接收消息的接口,简化企业应用的开发。  ActiveMQ是该协 议的典型实现。

STOMP                                                                                                                                        

STOMP Streaming Text Orientated Message Protocol  (面向流文本的消息协议),是一种MOM设计 的简单文本协议。  STOMP提供一个可互操作的连接格式,允许客户端与任意STOMP消息代理

Broker)进行交互。  ActiveMQ是该协议的典型实现,  RabbitMQ通过插件可以支持该协议。

AMQP

AMQPAdvanced Message Queuing Protocol  (高级消息队列协议),一个提供统一消息服务的应用  层标准,是应用层协议的一个开放标准,是一种MOM设计。基于此协议的客户端与消息中间件可传递 消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。   RabbitMQ是该协议的典型实     现。

MQTT                                                                                                                                          

MQTT Message Queuing Telemetry Transport  (消息队列遥测传输),IBM开发的一个即时通讯协 议,是一种二进制协议,主要用于服务器和低功耗IoT  (物联网)设备间的通信。该协议支持所有平     台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和致动器的通信协议。   RabbitMQ 过插件可以支持该协议。

二、  RocketMQ概述

1、 RocketMQ简介  

RocketMQ是一个统一消息引擎、轻量级数据处理平台。

RocketMQ是⼀款阿⾥巴巴开源的消息中间件。  20161128⽇,阿⾥巴巴向 Apache 软件基⾦会捐赠 RocketMQ,成为 Apache 孵化项⽬。  2017  9  25 ⽇, Apache 宣布 RocketMQ孵化成为 Apache  级项⽬(TLP ),成为国内⾸个互联⽹中间件在 Apache 上的顶级项⽬。

官⽹地址:  http://rocketmq.apache.org

 2、  RocketMQ发展历程

2007年,阿里开始五彩石项目,  Notify作为项目中 交易核心消息流转系统 ,应运而生。  Notify系统是 RocketMQ的雏形。

2010年,  B2B大规模使用ActiveMQ作为阿里的消息内核。阿里急需一个具有 海量堆积能力 的消息系 统。

2011年初,  Kafka开源。淘宝中间件团队在对Kafka进行了深入研究后,开发了一款新的MQ MetaQ

2012年,  MetaQ发展到了v3.0版本,在它基础上进行了进一步的抽象,形成了RocketMQ,然后就将其 进行了开源。

2015年,阿里在RocketMQ的基础上,又推出了一款专门针对阿里云上用户的消息系统AliwareMQ

2016年双十一,  RocketMQ承载了 万亿级 消息的流转,跨越了一个新的里程碑。  1128⽇,阿⾥巴巴  Apache 软件基⾦会捐赠 RocketMQ,成为 Apache 孵化项⽬。

2017  9  25 ⽇, Apache 宣布 RocketMQ孵化成为 Apache 顶级项⽬(TLP ),成为国内⾸个互联 ⽹中间件在 Apache 上的顶级项⽬。

第2章 RocketMQ的安装与启动

一、  基本概念  

1 消息(Message)

消息是指,消息系统所传输信息的物理载体,生产和消费数据的最小单位,每条消息必须属于一个主题。

2 主题(Topic)

Topic表示一类消息的集合,每个主题包含若干条消息,每条消息只能属于一个主题,是RocketMQ进行消息订阅的基本单位。 topic:message 1:n message:topic 1:1

一个生产者可以同时发送多种Topic的消息;而一个消费者只对某种特定的Topic感兴趣,即只可以订阅 和消费一种Topic的消息。 producer:topic 1:n consumer:topic 1:1

 

3 标签(Tag

为消息设置的标签,用于同一主题下区分不同类型的消息。来自同一业务单元的消息,可以根据不同业 务目的在同一主题下设置不同标签。标签能够有效地保持代码的清晰度和连贯性,并优化RocketMQ供的查询系统。消费者可以根据Tag实现对不同子主题的不同消费逻辑,实现更好的扩展性。

Topic是消息的一级分类,Tag是消息的二级分类。 

Topic:货物

tag=上海

tag=江苏

tag=浙江

------- 消费者 -----

topic=货物 tag = 上海

topic=货物 tag = 上海|浙江

topic=货物 tag = *

  1. 队列(Queue

存储消息的物理实体。一个Topic中可以包含多个Queue,每个Queue中存放的就是该Topic的消息。一 TopicQueue也被称为一个Topic中消息的分区(Partition)。

一个TopicQueue中的消息只能被一个消费者组中的一个消费者消费。一个Queue中的消息不允许同 一个消费者组中的多个消费者同时消费。

 

在学习参考其它相关资料时,还会看到一个概念:分片(Sharding)。分片不同于分区。在RocketMQ 中,分片指的是存放相应TopicBroker。每个分片中会创建出相应数量的分区,即Queue,每个 Queue的大小都是相同的。

 

5、消息标识(MessageId/Key

RocketMQ中每个消息拥有唯一的MessageId,且可以携带具有业务标识的Key,以方便对消息的查询。 不过需要注意的是,MessageId有两个:在生产者send()消息时会自动生成一个MessageIdmsgId)当消息到达Broker后,Broker也会自动生成一个MessageId(offsetMsgId)msgIdoffsetMsgIdkey 称为消息标识。

msgId:由producer端生成,其生成规则为:

producerIp + 进程pid + MessageClientIDSetter类的ClassLoaderhashCode +

当前时间 + AutomicInteger自增计数器

offsetMsgId:由broker端生成,其生成规则为: brokerIp  + 物理分区的offsetQueue中的

偏移量)

key:由用户指定的业务相关的唯一标识

 

二、系统架构

RocketMQ架构上主要分为四部分构成:

1.Producer

消息生产者,负责生产消息。Producer通过MQ的负载均衡模块选择相应的Broker集群队列进行消息投 递,投递的过程支持快速失败并且低延迟。

例如业务系统产生的日志写入到MQ过程,就是消息生产的过程

再如电商平台中用户提交的秒请求写入到MQ过程,就是消息生产的过程

RocketMQ中的消息生产者都是以生产者组(Producer Group)的形式出现的。生产者组是同一类生产 者的集合,这类Producer发送相同Topic类型的消息。一个生产者组可以同时发送多个主题的消息。

2.Consumer

消息消费者,负责消费消息。一个消息消费者会从Broker服务器中获取到消息,并对消息进行相关业务 处理。

例如QoS MQ       读取日志并对日志进行解析处理的过程就是消息消费的过程

再如电商平台的业务系统从MQ读取到秒杀请求并对请求进行处理的过程就是消息消费的过程。

RocketMQ中的消息消费者都是以消费者组(Consumer Group)的形式出现的。消费者组是同一类消 费者的集合,这类Consumer消费的是同一个Topic类型的消息。消费者组使得在消息消费方面,实现 负载均衡 (将一个Topic中的不同的Queue平均分配给同一个Consumer Group的不同的Consumer,注 意,并不是将消息负载均衡)和 容错 (一个Consmer挂了,该Consumer Group中的其它Consumer可 以接着消费原Consumer消费的Queue)的目标变得非常容易。

 

举报

相关推荐

0 条评论