1.各队列性能比较。
测试一:
测试场景:
Scenario A: Enqueuing 20,000 messages of 1024 bytes each, then dequeuing them afterwards.
Scenario B: Enqueuing and dequeuing simultaneously 20,000 messages of 1024 bytes each.
Scenario C: Enqueuing and dequeuing simultaneously 200,000 messages of 32 bytes each.
Scenario D: Enqueuing and dequeuing simultaneously 200 messages of 32768 bytes each.
Scenario A
Scenario B
Scenario C
Scenario D
测试二:
显示的是发送和接受的每秒钟的消息数。整个过程共产生1百万条1K的消息。
总结:ZeroMq 最好,RabbitMq 次之, ActiveMq 最差,ActiveMq是Java,RabbitMQ是Erlang,理论上,RabbitMQ的性能比ActiveMq更强,是非Java系统的首选,ActiveMq是Java的,整套系统如果本来就是Java的,配合的默契更佳。高并发下amqp协议rabbitMq明显优于stomp协议activeMQ,amqp协议查看:http://blog.163.com/clevertanglei900@126/blog/static/111352259201011121041853/
2.持久化消息比较。
zeroMq不支持,activeMq和rabbitMq都支持。持久化消息主要是指:MQ down或者MQ所在的服务器down了,消息不会丢失的机制。
3.可靠性,可用性比较。
RabbitMq 最好,ActiveMq次之, ZeroMq 最差。ActiveMq和ZeroMq都会出现丢数据
4.Kafka
Kafka设计的初衷就是处理日志的,可以看做是一个日志系统,针对性很强,所以它并没有具备一个成熟MQ应该具备的特性
5.ZoreMQ
引用官方的说法: “ZMQ (以下 ZeroMQ 简称 ZMQ)是一个简单好用的传输层,像框架一样的一个 socket library,他使得 Socket 编程更加简单、简洁和性能更高。是一个消息处理队列库,可在多个线程、内核和主机盒之间弹性伸缩。ZMQ 的明确目标是“成为标准网络协议栈的一部分,之后进入 Linux 内核”。现在还未看到它们的成功。但是,它无疑是极具前景的、并且是人们更加需要的“传统”BSD 套接字之上的一层封装。ZMQ 让编写高性能网络应用程序极为简单和有趣。”
与 RabbitMQ 相比,ZMQ 并不像是一个传统意义上的消息队列服务器,事实上,它也根本不是一个服务器,它更像是一个底层的网络通讯库,在 Socket API 之上做了一层封装,将网络通讯、进程通讯和线程通讯抽象为统一的 API 接口。
ZMQ类似于 Socket 的一系列接口,他跟 Socket 的区别是:普通的 socket 是端到端的(1:1的关系),而 ZMQ 却是可以N:M 的关系,人们对 BSD 套接字的了解较多的是点对点的连接,点对点连接需要显式地建立连接、销毁连接、选择协议(TCP/UDP)和处理错误等,而 ZMQ 屏蔽了这些细节,让你的网络编程更为简单。ZMQ 用于 node 与 node 间的通信,node 可以是主机或者是进程。
相关推荐
ActiveMQ RabbitMQ RokcetMQ Kafka实战 消息队列中间件视频教程
ActiveMQ RabbitMQ RokcetMQ Kafka实战 消息队列中间件视频教程
本面试专题系列涵盖了三个关键的分布式消息中间件:ActiveMQ、RabbitMQ和Kafka,它们都是实现高效、可靠数据传输的重要工具。下面我们将深入探讨这三个组件的核心概念、特点以及在实际应用中的使用场景。 首先,...
本篇文章将深入探讨四种常用的消息中间件:RabbitMQ、ActiveMQ、RocketMQ和Kafka,以及它们在实际应用中的特点和使用经验。 首先,RabbitMQ是一款基于AMQP(Advanced Message Queuing Protocol)协议的开源消息...
本面试专题系列涵盖了三个关键的分布式消息中间件:ActiveMQ、RabbitMQ和Kafka,这些都是Java开发者和技术面试者需要深入了解的重要知识点。下面我们将逐一探讨这三个组件的核心概念、使用场景以及在实际开发中的...
【Java】分布式消息中间件(ActiveMQ、RabbitMQ、Kafka、RocketMQ),负载均衡中间件Nginx+LVS
#### Kafka与Activemq、Rabbitmq、ZeroMq、Rocketmq的比较 在现代分布式系统中,消息中间件(Message Queue, MQ)扮演着至关重要的角色,它们用于在分布式组件之间传输消息,帮助解决网络延迟、组件故障等问题,...
【Java】分布式消息中间件(ActiveMQ、RabbitMQ、Kafka、RocketMQ),负载均衡中间件Nginx+LVS_pgj
面试中,候选人往往会被问及关于消息中间件的知识,特别是ActiveMQ、RabbitMQ和Kafka这三大主流消息队列系统的理解与应用。本系列专题将深入探讨这三个工具,以帮助你更好地准备面试。 1. **ActiveMQ**: - ...
高性能架构面试题系列:Nginx+ActiveMQ+RabbitMQ+Kafka 请解释Nginx如何处理HTTP请求。 Nginx使用反应器模式。主事件循环等待操作系统发出准备事件的信号,这样数据就可以从套接字读取,在该实例中读取到缓冲区并...
RabbitMQ、RocketMQ、Kafka、ActiveMQ 消息中间件常见的面试题目 了解消息中间件的使用场景是非常重要的,面试官可能会问你为什么使用消息队列,消息队列都有哪些使用场景,然后你项目里具体是什么场景,说说你在这...
消息中间件 ActiveMQ RABBITMQ rocketMq kafka ActiveM]q消息中间件 ActiveMQ RABBITMQ rocketMq kafka ActiveM]q
5.比较关注的比较, RabbitMQ 和 Kafka RabbitMq 比Kafka 成熟,在可用性上,稳定性上,可靠性上, RabbitMq 胜于 Kafka (理论上)。 另外,Kafka 的定位主要在日志等方面, 因为Kafka 设计的初衷就是处理日志的,...
消息中间件技术选型,ActiveMQ、Apollo、RabbitMQ、RocketMQ、Kafka、Redis、ZeroMQ多维护对比分析
本项目"message-queue-parent"提供了对多个消息队列框架的示例代码,包括ActiveMQ、Kafka、RabbitMQ和RocketMQ。这些消息队列在Java开发中广泛使用,用于实现异步处理、解耦系统组件以及提高系统的可扩展性。 首先...
当前使用较多的消息中间件有RabbitMQ、RocketMQ、ActiveMQ、Kafka、ZeroMQ、MetaMQ等。本套视频以Apache的ActiveMQ作为切入点,分为基础/实战/面试上中下三大部分,带你从零基础入门到熟练掌握ActiveMQ,能够结合...
当前使用较多的消息中间件有RabbitMQ、RocketMQ、ActiveMQ、Kafka、ZeroMQ、MetaMQ等, 本次以Apache的ActiveMQ作为切入点,分为基础/实战/面试上中下三大部分,将带着同学们 从零基础入门到熟练掌握ActiveMQ,能够...
MQ是消息中间件,是一种在分布式系统中应用程序借以传递消息的媒介,常用的有ActiveMQ,RabbitMQ,kafka。ActiveMQ是Apache下的开源项目,完全支持JMS1.1和J2EE1.4规范的JMS Provider实现。 特点: 1、支持多种...