首页 常见问题 消息队列有哪些

消息队列有哪些

Jun 29, 2020 am 11:30 AM
消息队列

消息队列有:1、RabbitMQ,是一个在AMQP基础上完成的,可复用的企业消息系统,是当前最主流的消息中间件之一;2、ActiveMQ,是一个完全支持JMS1.1和J2EE1.4规范的【JMS Provider】实现。

消息队列有哪些

1 RabbitMQ

RabbitMQ 2007年发布,是一个在AMQP(高级消息队列协议)基础上完成的,可复用的企业消息系统,是当前最主流的消息中间件之一。

主要特性:

  • 可靠性: 提供了多种技术可以让你在性能和可靠性之间进行权衡。这些技术包括持久性机制、投递确认、发布者证实和高可用性机制;

  • 灵活的路由: 消息在到达队列前是通过交换机进行路由的。RabbitMQ为典型的路由逻辑提供了多种内置交换机类型。如果你有更复杂的路由需求,可以将这些交换机组合起来使用,你甚至可以实现自己的交换机类型,并且当做RabbitMQ的插件来使用;

  • 消息集群:在相同局域网中的多个RabbitMQ服务器可以聚合在一起,作为一个独立的逻辑代理来使用;

  • 队列高可用:队列可以在集群中的机器上进行镜像,以确保在硬件问题下还保证消息安全;

  • 多种协议的支持:支持多种消息队列协议;服务器端用Erlang语言编写,支持只要是你能想到的所有编程语言;

  • 管理界面: RabbitMQ有一个易用的用户界面,使得用户可以监控和管理消息Broker的许多方面;

  • 跟踪机制:如果消息异常,RabbitMQ提供消息跟踪机制,使用者可以找出发生了什么;

  • 插件机制:提供了许多插件,来从多方面进行扩展,也可以编写自己的插件;

2 ActiveMQ

ActiveMQ是由Apache出品,ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现。它非常快速,支持多种语言的客户端和协议,而且可以非常容易的嵌入到企业的应用环境中,并有许多高级功能。

主要特性:

  • 服从 JMS 规范:JMS 规范提供了良好的标准和保证,包括:同步或异步的消息分发,一次和仅一次的消息分发,消息接收和订阅等等。遵从 JMS 规范的好处在于,不论使用什么 JMS 实现提供者,这些基础特性都是可用的;

  • 连接性:ActiveMQ 提供了广泛的连接选项,支持的协议有:HTTP/S,IP 多播,SSL,STOMP,TCP,UDP,XMPP等等。对众多协议的支持让 ActiveMQ 拥有了很好的灵活性。

  • 支持的协议种类多:OpenWire、STOMP、REST、XMPP、AMQP ;

  • 持久化插件和安全插件:ActiveMQ 提供了多种持久化选择。而且,ActiveMQ 的安全性也可以完全依据用户需求进行自定义鉴权和授权;

  • 支持的客户端语言种类多:除了 Java 之外,还有:C/C++,.NET,Perl,PHP,Python,Ruby;

  • 代理集群:多个 ActiveMQ 代理可以组成一个集群来提供服务;

  • 异常简单的管理:ActiveMQ 是以开发者思维被设计的。所以,它并不需要专门的管理员,因为它提供了简单又使用的管理特性。有很多中方法可以监控 ActiveMQ 不同层面的数据,

  • 包括使用在 JConsole 或者 ActiveMQ 的Web Console 中使用 JMX,通过处理 JMX 的告警消息,通过使用命令行脚本,甚至可以通过监控各种类型的日志。

3 RocketMQ

RocketMQ出自 阿里公司的开源产品,用 Java 语言实现,在设计时参考了 Kafka,并做出了自己的一些改进,消息可靠性上比 Kafka 更好。RocketMQ在阿里集团被广泛应用在订单,交易,充值,流计算,消息推送,日志流式处理,binglog分发等场景。

  • 是一个队列模型的消息中间件,具有高性能、高可靠、高实时、分布式特点;

  • Producer、Consumer、队列都可以分布式;

  • Producer向一些队列轮流发送消息,队列集合称为Topic,Consumer如果做广播消费,则一个consumer实例消费这个Topic对应的所有队列,如果做集群消费,

  • 则多个Consumer实例平均消费这个topic对应的队列集合;

  • 能够保证严格的消息顺序;

  • 提供丰富的消息拉取模式;

  • 高效的订阅者水平扩展能力;

  • 实时的消息订阅机制;

  • 亿级消息堆积能力;

  • 较少的依赖;

4 Kafka

Apache Kafka是一个分布式消息发布订阅系统。它最初由LinkedIn公司基于独特的设计实现为一个分布式的提交日志系统( a distributed commit log),,之后成为Apache项目的一部分。Kafka系统快速、可扩展并且可持久化。它的分区特性,可复制和可容错都是其不错的特性。

  • 快速持久化,可以在O(1)的系统开销下进行消息持久化;

  • 高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率; 

  • .完全的分布式系统,Broker、Producer、Consumer都原生自动支持分布式,自动实现负载均衡;

  • 支持同步和异步复制两种HA;

  • 支持数据批量发送和拉取;

  • zero-copy:减少IO操作步骤;

  • 数据迁移、扩容对用户透明;

  • 无需停机即可扩展机器;

  • 其他特性:严格的消息顺序、丰富的消息拉取模型、高效订阅者水平扩展、实时的消息订阅、亿级的消息堆积能力、定期删除机制;

以上是消息队列有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Java Websocket开发实战:如何实现消息队列功能 Java Websocket开发实战:如何实现消息队列功能 Dec 02, 2023 pm 01:57 PM

JavaWebsocket开发实战:如何实现消息队列功能引言:随着互联网的迅速发展,实时通信变得越来越重要。在许多Web应用程序中,需要通过实时消息传递来实现实时更新和通知功能。JavaWebsocket是一种在Web应用程序中实现实时通信的技术。本文将介绍如何利用JavaWebsocket来实现消息队列功能,并提供具体的代码示例。消息队列的基本概念消

如何在FastAPI中使用消息队列进行异步任务处理 如何在FastAPI中使用消息队列进行异步任务处理 Jul 30, 2023 pm 09:21 PM

如何在FastAPI中使用消息队列进行异步任务处理引言:在Web应用程序中,经常会遇到需要处理耗时的任务,例如发送电子邮件、生成报表等。如果将这些任务放在同步的请求-响应流程中,会导致用户需要等待较长时间,降低用户体验和服务器的响应速度。为了解决这个问题,我们可以使用消息队列来进行异步任务处理。本文将介绍如何在FastAPI框架中使用消息队列进行异步任务的处

Golang开发:使用NATS构建可靠的消息队列 Golang开发:使用NATS构建可靠的消息队列 Sep 21, 2023 am 11:21 AM

Golang开发:使用NATS构建可靠的消息队列,需要具体代码示例引言:在现代分布式系统中,消息队列是一个重要的组件,用于处理异步通信、解耦系统组件和实现可靠的消息传递。本文将介绍如何使用Golang编程语言和NATS(全称是"高性能可靠消息系统")来构建一个高效、可靠的消息队列,并提供具体的代码示例。什么是NATS?NATS是一种轻量级的、开源的消息系统。

Redis在消息队列中的妙用 Redis在消息队列中的妙用 Nov 07, 2023 pm 04:26 PM

Redis在消息队列中的妙用消息队列是一种常见的解耦架构,用于在应用程序之间传递异步消息。通过将消息发送到队列中,发送者可以在不等待接收者响应的情况下继续执行其他任务。而接收者可以在适当的时间从队列中获取消息并进行处理。Redis是一种常用的开源内存数据库,具备高性能和持久性存储的能力。在消息队列中,Redis的多种数据结构和优秀的性能使其成为一个理想的选择

C#开发中如何处理分布式事务和消息队列 C#开发中如何处理分布式事务和消息队列 Oct 09, 2023 am 11:36 AM

C#开发中如何处理分布式事务和消息队列引言:在今天的分布式系统中,事务和消息队列是非常重要的组件。在处理数据一致性和系统解耦方面,分布式事务和消息队列起着至关重要的作用。本文将介绍如何在C#开发中处理分布式事务和消息队列,并给出具体的代码示例。一、分布式事务分布式事务是指跨多个数据库或服务的事务。在分布式系统中,如何保证数据的一致性成为一大挑战。下面介绍两种

如何在Java中使用Linux脚本操作实现消息队列 如何在Java中使用Linux脚本操作实现消息队列 Oct 05, 2023 am 08:09 AM

如何在Java中使用Linux脚本操作实现消息队列,需要具体代码示例消息队列是一种常见的通信机制,用于在不同进程之间传递数据。在Java中,我们可以使用Linux脚本操作来实现消息队列,这样可以轻松地将消息发送到队列中或从队列中接收消息。在本文中,我们将详细介绍如何使用Java和Linux脚本来实现消息队列,并提供具体的代码示例。为了开始使用Java和Lin

深入了解Kafka消息队列的底层实现机制 深入了解Kafka消息队列的底层实现机制 Feb 01, 2024 am 08:15 AM

Kafka消息队列的底层实现原理概述Kafka是一个分布式、可扩展的消息队列系统,它可以处理大量的数据,并且具有很高的吞吐量和低延迟。Kafka最初是由LinkedIn开发的,现在是Apache软件基金会的一个顶级项目。架构Kafka是一个分布式系统,由多个服务器组成。每个服务器称为一个节点,每个节点都是一个独立的进程。节点之间通过网络连接,形成一个集群。K

如何利用Redis和Golang实现简单的消息队列 如何利用Redis和Golang实现简单的消息队列 Aug 01, 2023 am 08:09 AM

如何利用Redis和Golang实现简单的消息队列引言消息队列被广泛应用于各种应用场景,如解耦系统组件、削峰填谷、异步通信等。本文将介绍如何使用Redis和Golang实现简单的消息队列,帮助读者了解消息队列的基本原理和实现方式。Redis简介Redis是一个使用C语言编写的开源内存数据库,提供了键值对存储和其他常用数据结构的处理功能。Redis以其高性能、