ActiveMQ、RabbitMQ、ZeroMQ比较

​​​​​​一、定义对比

  • ActiveMQ

      ActiveMQ是Apache开发的开源消息中间件,Java实现,基于JMS1.1及J2EE 1.4规范。

  • RabbitMQ

     RabbitMQ 是由 LShift 提供的一个 Advanced MessageQueuing Protocol (AMQP) 的开源实现,由         以高性能、健壮以及可伸缩性出名的 Erlang 写成,因此也是继承了这些优点。

  • ZeroMQ

     ZeroMQ是由iMatix公司使用C语言开发的高性能消息中间件,是对socket的封装,在发送端存消息。

二、表格对比

 ActiveMQRabbitMQZeroMQ
遵循规范JMS1.1及J2EE 1.4AMPQ---
架构模型消息代理架构Broker消息代理架构BrokerC/S架构
实现语言JavaErlangC/C++
支持消息协议StompAMPQ、Stomp等---
主要推动力量Apache、RedhatLshift、Vmware、SpringSourceiMatix
支持编程语言C,Java,PythonC,Java,PythonC,Java,Python
编程复杂度复杂简单中等
持久化支持支持,不支持第三方数据库发送端缓存
性能NormalNormalHigh
内存使用率HighHighNormal

三、附录

  • AMPQ

AMQP即Advanced Message Queuing Protocol (高级消息队列协议),主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。AMQP协议更多用在企业系统内,对数据一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求还在其次。(金融行业)

  • STOMP

STOMP即Simple (or Streaming) Text Orientated Messaging Protocol(简单(流)文本定向消息协议),它提供了一个可互操作的连接格式,允许STOMP客户端与任意STOMP消息代理(Broker)进行交互。STOMP协议由于设计简单,易于开发客户端,因此在多种语言和多种平台上得到广泛地应用。

STOMP协议的前身是TTMP协议(一个简单的基于文本的协议),专为消息中间件设计。

STOMP是一个非常简单和容易实现的协议,其设计灵感源自于HTTP的简单性。尽管STOMP协议在服务器端的实现可能有一定的难度,但客户端的实现却很容易。例如,可以使用Telnet登录到任何的STOMP代理,并与STOMP代理进行交互。

 

 

 

 

 

转载于:https://my.oschina.net/idea813/blog/1604038

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ActiveMQ是基于Java的消息队列中间件,支持传输协议包括TCP、STOMP、MQTT等。它使用JMS(Java消息服务)API,支持消息发布/订阅、点对点等模式。ActiveMQ提供了可靠性、安全性、事务特性等,适用于大规模数据交换场景。[^1] RabbitMQ是一个开源的AMQP(高级消息队列协议)消息代理软件,使用Erlang实现。它支持多种编程语言,包括Java、C#、Python、PHP等,具有轻量、高可用、易用等特点,适用于分布式系统、大规模数据处理等场景。[^2] ZeroMQ,又称为0MQ,是一个高性能、异步消息库,可以在不同的应用、进程、线程之间进行消息传输。它支持多种数据传输协议和模式,包括PUSH-PULL、PUB-SUB、REQ-REP等,具有轻量、快速、灵活等特点,适用于高并发、消息即时响应等场景。[^3] Kafka是由Apache开源的高吞吐量、分布式发布订阅消息系统,使用Scala编写。它支持发布订阅、消息存储等功能,具有高可靠性、可扩展性、高吞吐量等特点,适用于日志收集、数据分析等场景。[^4] MetaMQ是一款国产的开源消息队列中间件,支持基于HTTP协议的消息服务,使用Java语言编写。它具有高性能、高并发等特点,适用于互联网金融、物联网等场景。[^5] RocketMQ是阿里巴巴开源的分布式消息中间件,支持多种发送模式,具有高可用性、高性能、低延迟等特点,适用于大规模消息处理、分布式系统等场景。[^6]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值