主流MQ对比和选型

在以下几个我们比较关心的维度进行对比

| | ActiveMQ | RabbitMQ | RocketMQ | kafka |
| 官网 | https://activemq.apache.org/ | https://www.rabbitmq.com/ | https://rocketmq.apache.org/ | https://kafka.apache.org/ |
| github | https://github.com/apache/activemq | https://github.com/rabbitmq | https://github.com/apache/rocketmq | https://github.com/apache/kafka |
| 开发语言(二次开发参考) | Java | Erlang | Java | Scala |
| SDK语言支持(技术选型和二次开发参考) | Java、C、C++、C#、Ruby、Perl、Python、PHP等 | Java、C#、Erlang、.Net | Java、C++、C#、Go | Scala |
| 协议支持 | OpenWireStompAMQPMQTT、JMS | AMQP、STOMP、MQTT、 RabbitMQ Streams | TCP、JMS、 OpenMessaging | TCP |
| 是否支持事务 | 支持 *** ** * ** *** 在 ActiveMQ 中,事务消息通常与会话(Session)对象一起使用。您可以创建一个事务性会话(Transaction Session),然后在事务中发送或接收消息。 | 支持 *** ** * ** *** 在 RabbitMQ 中,事务消息通常与通道(Channel)对象一起使用。您可以在通道上开启一个事务,然后在事务中发送或接收消息。 | 支持 *** ** * ** *** 发送半消息(Half Message)->本地事务执行->确认事务消息 | Kafka在0.11.0.0版本开始支持事务消息 *** ** * ** *** 使用initTransactions()、beginTransaction()、sendOffsetToTransaction()和commitTransaction()来完成事务消息发送和消费的 |
| 是否支持批量消息 | 不支持 | 不支持 | 支持,具有同步模式,避免消息丢失 | 支持,使用异步生产者 |
| 消息可靠性 | 有较低的概率丢失数据 | | 经过参数优化配置,消息可以做到0丢失 | 经过参数优化配置,消息可以做到0丢失 |
| 单机吞吐量 | 万级 | 万级 | 10万级 | 10万级 |
| 高可用性和故障转移 | 支持,取决于存储,如果使用 levelDB,则需要 ZooKeeper 服务器 | 支持,集群方式通过镜像队列,将队列和它的消息存储复制到集群中的多个节点 | 支持主从模式,无需其他套件 | 支持,需要 ZooKeeper 服务器 |
| 管理台 | 一般 | 好 | 无,有社区版本web | 无 |
| 社区活跃度 | 高 | 高 | 中 | 高 |
| 持久化方式 | 内存、文件、数据库 | 内存、文件,支持数据堆积,但数据堆积会影响生产速率 | 磁盘文件 | 磁盘文件,只要磁盘容量足够,可以做到无限消息堆积 |

适用场景 非常成熟,功能强大 、性能一般;主要是基于解耦和异步来用的,较少在大规模吞吐的场景中使用 中小型公司,基础架构研发能力较弱,采用RabbitMQ是不错的选择,但是Erlang语言环境二次开发困难 性能较好,部署简单;有较大吞吐量需求,同时可能会有大量的topic,基础架构研发实力较强的大公司,完全可以采用RocketMQ 性能较好,超高的吞吐量;非常适合在大数据领域中数据收集以及日志采集中;单机topic不宜过多超过64个队列/分区性能下降
相关推荐
方大刚2334 分钟前
【Scrapy】 深入了解 Scrapy 中间件中的 process_spider_input 方法
scrapy·中间件
方大刚2336 分钟前
【Scrapy】Scrapy 中间件等级设置规则
scrapy·中间件
龙洋静3 小时前
RabbitMq - Java客户端基础【简单案例 +Work模型】
java·rabbitmq·java-rabbitmq
coisini.cn7 小时前
基于CentOS Stream 9平台搭建RabbitMQ3.13.4以及开机自启
linux·运维·服务器·rabbitmq·centos stream 9
龙洋静7 小时前
RabbitMQ中常用的三种交换机【Fanout、Direct、Topic】
分布式·rabbitmq
java6666688887 小时前
使用RabbitMQ实现可靠的消息传递机制
分布式·rabbitmq·ruby
执键行天涯7 小时前
【RabbitMQ问题踩坑】RabbitMQ设置手动ack后,消息队列有多条消息,只能消费一条,就不继续消费了,这是为什么 ?
rabbitmq·ack
szc17677 小时前
RabbitMq 消息确认和退回机制
分布式·rabbitmq
方大刚2337 小时前
【Scrapy】深入了解 Scrapy 下载中间件中的 from_crawler 方法
爬虫·scrapy·中间件
方大刚2338 小时前
【Scrapy】深入了解 Scrapy 中间件中的 process_spider_output 方法
scrapy·中间件