RocketMQ概述
一、MQ概述
1、MQ简介
MQ,Message Queue,是一种提供消息队列服务的中间件,也称之为消息中间件,是一套提供了消息的生产、存储、消费全过程的API的软件系统。消息即数据。
2、MQ用途
限流削峰
MQ可以在系统的超量请求暂存其中,以便系统后期可以慢慢的进行处理,从而避免了请求的丢失或系统被压垮。
异步解耦
上游系统对下游系统的调用若为同步调用,则会大大降低系统的吞吐量与并发度,且系统的耦合度非常的高。而异步调用则会解决这些问题。所以在两个系统若是要实现异步调用的话,一般性的做法就是,在两个系统之间添加一个MQ层。
数据收集
分布式系统会产生海量级别的数据流,如:业务日志、监控数据、用户行为等。针对这些数据流进行实时或批量的采集汇总,然后对这些数据流进行大数据的分析,这是当前互联网平台的必备技术。通过MQ完成此类数据收集是最好的选择。
3.常见的MQ产品
ActiveMQ
ActiveMQ是早期使用java语言编写的一种MQ产品。早期很多的公司还是在使用的,但是现在社区活跃度已经很低了,现在项目上已经很少能过看见这个MQ了。
RabbitMQ
RabbitMQ是使用ErLang语言编写的MQ产品,其吞吐量较kafka和RocketMQ要低。且由于不是用java语言编写的,公司要对其进行定制化开发难度比较大。
Kafka
Kafka是Scala/Java语言编写的MQ产品,它的最大的特点就是具有很高的吞吐量,所以常用于大数据领域的实时计算、日志采集等场景。但是其没有遵循任何的MQ协议,而是使用的自研协议。
RocketMQ
RocketMQ是使用Java开发的MQ产品。经过 数十年的阿里双十一的考验。性能与稳定性非常高。其没有遵循任何的MQ协议,而是使用的自研协议。对于Spring Cloud Alibaba ,仅仅支持RabbitMQ、kafka ,但是提倡使用RocketMQ。
4、MQ常见协议
一般情况下MQ是要遵循一些规定性的协议的。常见的协议如下:
JMS
JMS,Java Messaging Service(Java消息服务)。是Java平台上有关MOM(Message Oriented Middleware,面向消息的中间件 PO/OO/AO)的技术规范,他便于消息系统中的Java应用程序进行消息交换,并且通常提供标准的产生、发送、接受消息的接口,简化企业应用的开发。ActiveMq是该协议的典型实现。
STOMP
STOMP,Streaming Text orientated Message Protocol(面向流文本的消息协议),是一种MOM设计的简单文本协议。STOMP提供一个可互操作的连接格式,允许客户端与任意STOMP消息代理(Broker)进行交互。ActiveMQ是该协议的典型实现,RabbitMQ可以通过插件支持该协议。
AMQP
Advanced Message Queuing Protocol(高级消息队列协议),一个提供统一消息服务的应用层标准,是应用层协议的一个开放标准,是一种MOM的设计。基于此协议的客户端与中间件的可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。RabbitMQ是该协议的典型实现。
MQTT
MQTT,Message Queuing Telemetry Transport(消息队列遥测传输),是IBM开发的一个即时通讯协议,是一种二进制协议,主要用于服务器和低功耗IoT(物联网)设备间的通信。该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和致动器的通信协议。RabbitMQ通过插件可以支持该协议。
二、RocketMQ概述
1、RocketMQ的简介
RocketMQ是一个统一消息引擎、轻量级数据处理平台。
RocketMQ是一款阿里巴巴开源的消息中间件。2016年11月28日,阿里巴巴向Apache软件基金会捐赠RocketMQ,成为Apache孵化项目。2017年9月25日,Apache宣布RocketMQ孵化成为Apache顶级项目(TLP),成为国内首个互联网中间件Apache 上的顶级项目。
官网地址:
2、RocketMQ的发展历程
2007年,阿里开始五彩石项目,Notify作为项目中交易核心消息流转系统,应运而生。Notify系统是RocketMQ的雏形。
2010年,B2B大规模使用ActiveMQ作为阿里的消息内核。阿里急需一个具有海量堆积能力的消息系
2011年初,Kafka开源。淘宝中间件团队对Kafka进行的深入的研究,开发了一款新的MQ,MetaMQ
2012年,MetaMQ发展到了v3.0版本,在他的基础上进行了一些抽象,形成了RoketMQ,然后就将其进行了开源。
2015年,阿里在RocketMQ的基础上,又推出了一款专门针对阿里云上用户的消息系统Aliware MQ。
2016年11月28日,阿里巴巴向Apache软件基金会捐赠RocketMQ,成为Apache孵化项目。
2017年9月25日,pache宣布RocketMQ孵化成为Apache顶级项目(TLP),成为国内首个互联网中间件在。