消息队列

消息队列(二)——技术选型,如何选择合适的消息中间件

2019-12-09  本文已影响0人  Jerry_Liang

以下是本消息队列系列文章的传送门:


在了解了消息队列的常用场景后,我们考虑接下来的选型问题。如今使用较多的消息队列有ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ等,以及部分数据库如Redis也可以实现消息队列功能。我们该选择哪一种来引入我们的项目中呢?那么接下来,主要分析关于各大主流消息队列的特性与优缺点。

1. RabbitMQ


1.1 概述

RabbitMQ是使用Erlang编写的一个开源的消息队列,本身支持很多的协议:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量级,更适合于企业级的开发。同时实现了Broker构架,这意味着消息在发送给客户端时先在中心队列排队。对路由,负载均衡或者数据持久化都有很好的支持。

1.2 特性

1.3 优缺点

优点

缺点

2.Redis


Redis是一个基于Key-Value对的NoSQL数据库,开发维护很活跃。虽然它是一个Key-Value数据库存储系统,但它本身支持MQ功能,所以完全可以当做一个轻量级的队列服务来使用。对于RabbitMQ和Redis的入队和出队操作,各执行100万次,每10万次记录一次执行时间。测试数据分为128Bytes、512Bytes、1K和10K四个不同大小的数据。实验表明:入队时,当数据比较小时Redis的性能要高于RabbitMQ,而如果数据大小超过了10K,Redis则慢的无法忍受;出队时,无论数据大小,Redis都表现出非常好的性能,而RabbitMQ的出队性能则远低于Redis。

3.ZeroMQ


3.1 概述

ZeroMQ号称最快的消息队列系统,基于c语言开发的。它跟其它MQ有着本质的区别,它根本就不是一个消息队列服务器,更像是一组底层网络通讯库,对原有的Socket API加上一层封装,使用时只需要引入相应jar包即可。

3.2 特性

3.3 应用场景

虽然ZeroMQ的吞吐量相比于其他MQ的吞吐量大了不是一个级别的,但由于它的不可靠传输性质(不保证数据不丢失),我们往往不会把它用在需要保证数据不丢失的场景中(除非我们自己扩展它保证数据的可靠性,但很明显,成本是相对较高的)。

4.ActiveMQ


4.1概述

ActiveMQ是Apache所提供的一个开源的消息系统,完全采用Java来实现,因此,它能很好地支持J2EE提出的JMS(Java Message Service,即Java消息服务)规范。JMS是一组Java应用程序接口,它提供消息的创建、发送、读取等一系列服务。JMS提供了一组公共应用程序接口和响应的语法,类似于Java数据库的统一访问接口JDBC,它是一种与厂商无关的API,使得Java程序能够与不同厂商的消息组件很好地进行通信。

4.2 特性

4.3 优缺点

优点

缺点

5.RocketMQ


5.1 概述

RocketMQ出自阿里的开源产品,用Java语言实现,在设计时参考了Kafka,并做出了自己的一些改进,消息可靠性上比Kafka更好。RocketMQ在阿里内部被广泛应用在订单,交易,充值,流计算,消息推送,日志流式处理,binglog分发等场景。

5.2 主要特性

5.3 优缺点

优点

缺点

6.Kafka/jafka


6.1 概述

Kafka是Apache下的一个子项目,是一个高性能跨语言分布式发布/订阅消息队列系统,而Jafka是在Kafka之上孵化而来的,即Kafka的一个升级版。具有以下特性:快速持久化,可以在O(1)的系统开销下进行消息持久化;高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率;完全的分布式系统,Broker、Producer、Consumer都原生自动支持分布式,自动实现负载均衡;支持Hadoop数据并行加载,对于像Hadoop的一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案。Kafka通过Hadoop的并行加载机制统一了在线和离线的消息处理。Apache Kafka相对于ActiveMQ是一个非常轻量级的消息系统,除了性能非常好之外,还是一个工作良好的分布式系统。

6.2 主要特性

6.3 优缺点

优点

缺点

7. 常见消息中间件对比分析图


对比分析图

8.适用场景分析


从公司基础建设力量角度

从业务场景角度出发:

上一篇 下一篇

猜你喜欢

热点阅读