2016 - 2024

感恩一路有你

常见的消息队列 常见的消息队列有哪些,它们之间有什么区别?

浏览量:2235 时间:2021-03-11 18:56:41 作者:admin

常见的消息队列有哪些,它们之间有什么区别?

Rabbitmq:

Rabbitmq是一个基于Erlang语言的开源消息队列。Rabbitmq在数据一致性、稳定性和可靠性方面都非常优秀。它直接或间接地支持多种协议,并能很好地支持多种语言。然而,它的性能和吞吐量并不令人满意。由于Erlang语言的局限性,二次开发的成本很高。

Kafka:

Kafka是LinkedIn于2010年12月开发的分布式流媒体平台,开源。它现在是Apache的顶级项目,是一个高性能的跨语言分布式流媒体平台。快速持久化,消息持久化开销在O(1)以下;高吞吐量

ActiveMQ:

是Apache下的一个子项目,介于zeromq和rabbitmq之间。与rabbitmq类似,它可以用少量代码高效地实现高级应用场景,并且只需要较低的成本。被称为消息中间件的“瑞士军刀”。然而,ActiveMQ不够轻量级,并且当有许多队列时,它不能很好地支持。据说也有丢失信息的情况。

Rocketmq:

Rocketmq是阿里巴巴的开源消息中间件。目前,它在Apache中孵化,并在纯Java中开发。它具有高吞吐量,高可用性,适合大规模分销

1。首先,找出发送和使用消息的过程

2。首先,定义消息协议,如ActiveMQ、stomp、XMPP等。定义消息协议后,定义消息队列需要满足哪些场景

是否需要确保消息的可靠性?如果是这样的话,就必须使存储具有高可用性

就必须支持同步和异步消息

就必须保证消息的顺序

就必须支持延迟消息

很多开源的实现功能可以参考详细信息。例如,rocketmq是高度可靠的,Kafka是高吞吐量的,但是它不是高度可用的。

如何设计一个MQ消息队列?

通常,消息队列提供异步消息传递机制。在windows中,窗口的执行分为以下几个步骤:

1、窗口类声明

2、窗口类注册

3、创建窗口

4、显示窗口

5、消息循环。一般来说,当窗口中发生事件时,系统会以消息的形式将事件发送到消息队列,消息队列至少包括:消息类型、窗口句柄、附加参数等,当窗口在消息循环中时,系统使用消息队列。当窗口事件发生时,它会调用getmessage()函数将消息从消息队列中取出,交给您所在级别声明的窗口进程即回调函数进行处理,从而完成事件的响应。希望能对你有所帮助。

Microsoft消息队列的功能是什么?

有两种选择。

Scheme 1 Local message transaction table

生产者需要添加一个事务消息表。具体步骤如下:[1。生产者执行业务逻辑并将事务记录插入到消息表中。这两个操作在一个本地事务中

2。启动后台线程定期轮询消息表并将消息发送到消息队列

3。删除消息表中的消息,直到发送成功。

方案2需要消息队列支持,业务端提供回溯接口

1。生产端将准备好的消息发送到消息队列

2。在本地事务中,业务逻辑

3。根据执行结果确认或取消准备好的消息

4。消息队列将确保准备好的消息被确认或取消,并且消息队列将不断地向生产端请求执行结果,这要求生产端提供类似的回调函数。

在方案2中,消息队列取代了方案1中的消息表和后台线程轮询功能,但并非所有消息队列都支持此功能。支持Rocketmq。

方案1的开发工作量大,外部依赖性小

方案2的开发工作量小,但依赖于特定的消息队列。

常见的消息队列 队列和队列的区别 消息总线和消息队列的区别

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。