您的位置 首页 技术

消息中间件有哪些?

消息中间件有:1、Kafka主要为高吞吐量的订阅发布系统而设计,追求速度与持久化;2、RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议来实现;3、Ro…

消息中间件有:1、Kafka主要为高吞吐量的订阅发布系统而设计,追求速度与持久化;2、RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议来实现;3、RocketMQ是纯Java开发,具有高吞吐量。

消息中间件有:

Kafka、RabbitMQ、RocketMQ

1、Kafka

e24db24dbd4bc4942d4602b0143dc81.png

Kafka是LinkedIn开源的分布式发布-订阅消息系统,目前归属于Apache顶级项目。Kafka主要为高吞吐量的订阅发布系统而设计,追求速度与持久化。kafka中的消息由键、值、时间戳组成,kafka不记录每个消息被谁使用,只通过偏移量记录哪些消息是未读的,kafka中可以指定消费组来实现订阅发布的功能。

2、RabbitMQ

ad637f856007a47cb9224c62fcffb36.png

RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议来实现。AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。AMQP协议更多用在企业系统内,对数据一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求还在其次。

3、RocketMQ

RocketMQ是阿里开源的消息中间件,它是纯Java开发,具有高吞吐量、高可用性、适合大规模分布式系统应用的特点。RocketMQ思路起源于Kafka,但并不是Kafka的一个Copy,它对消息的可靠传输及事务性做了优化,目前在阿里集团被广泛应用于交易、充值、流计算、消息推送、日志流式处理、binglog分发等场景。支持的客户端语言不多,目前是Java及C++,其中C++还不成熟;

5、Kafka、RabbitMQ、RocketMQ对比

4e8d28213f16bb3d2d183d1cf124aba.png

1、Rabbitmq比kafka可靠,kafka更适合IO高吞吐的处理,比如ELK日志收集。

2、kafka具有高的吞吐量,内部采用消息的批量处理,zero-copy机制,数据的存储和获取是本地磁盘顺序批量操作,具有O(1)的复杂度,消息处理的效率很高。rabbitMQ在吞吐量方面稍逊于kafka,他们的出发点不一样,rabbitMQ支持对消息的可靠的传递,支持事务,不支持批量的操作;基于存储的可靠性的要求存储可以采用内存或者硬盘。

以上就是消息中间件有哪些?的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/90555.html

为您推荐

返回顶部