【RocketMQ】基本描述

一、MQ概述

1. MQ 简介

MQ,Message Queue,是一种提供消息队列服务的中间件,是一套提供了消息生产、存储、消费全过程API的软件系统。

2. MQ 用途

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

限流削峰

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

异步解耦

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

数据收集

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

3. 常见 MQ 产品

ActiveMQ

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

RabbitMQ

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

Kafka

Kafka是使用Scala/Java语言开发的一款MQ产品。其最大的特点就是高吞吐量,常用于大数据领域的实时计算、日志采集等场景。其没有遵循任何常见的MQ协议,而是使用自研协议。

RocketMQ

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

4. MQ 常见协议

JMS

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

STOMP

STOMP,Streaming Text Orientated Message Protocol,是一种MOM设计的简单文本协议。STOMP 提供一个可操作的连接格式,允许客户端与任意STOMP消息代理(Broker)进行交互。Active MQ是该协议的典型实现,Rabbit MQ通过插件可以支持该协议。

AQMP

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

MQTT

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

二、RocketMQ概述

1. RocketMQ简介

RocketMQ简介

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

RocketMQ是一款阿里巴巴开源的消息中间件。

2016年11月28日,阿里巴巴向Apache软件基金会捐赠RocketMQ,成为Apache的孵化项目。

2017年9月25日,Apache宣布RocketMQ孵化成为Apache顶级项目(TLP),成为国内首个网络中间件再Apache上的顶级项目。

官网地址:https://rocketmq.apache.org/

2. RocketMQ发展历程

RocketMQ发展历程

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

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

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

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

  • 2015年,阿里在RocketMQ的基础上,又推出了一款专门针对阿里云用户的消息系统 Aliware MQ v1.0。

  • 2016年双十一,RocketMQ承载了万亿级消息的流转,跨越了一个新的里程碑。11月28日,阿里巴巴向Apache软件基金会捐赠RocketMQ,成为Apache的孵化项目。

  • 2017年9月25日,Apache宣布RocketMQ孵化成为Apache顶级项目(TLP),成为国内首个网络中间件再Apache上的顶级项目。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值