常用的消息中间件

下面是常用消息中间件 RabbitMQActiveMQKafkaRocketMQRedis(Pub/Sub 模式) 的消息队列调研文档,包括各自的特点、优缺点以及对比分析。

1. RabbitMQ

简介

RabbitMQ 是基于 AMQP 协议的开源消息队列,擅长复杂消息路由,提供插件支持和可靠的消息传递。

特点
  • 协议支持:支持 AMQP、MQTT、STOMP。
  • 路由机制:支持 direct、fanout、topic 和 headers 等多种交换机类型。
  • 消息可靠性:通过消息确认、持久化和死信队列保障可靠性。
  • 插件扩展:支持丰富的插件,如延迟队列和监控工具。
优点
  • 成熟稳定,社区活跃。
  • 支持复杂的消息路由。
  • 灵活配置消息持久化和确认机制。
  • 丰富的管理工具和监控功能。
缺点
  • 高并发下性能有限(约 10 万 TPS)。
  • 消息堆积时性能下降较为显著。
  • 运维和调优相对复杂。

2. ActiveMQ

简介

ActiveMQ 是 Apache 基金会维护的开源消息代理,完全兼容 JMS,支持多种协议。

特点
  • 协议支持:支持 JMS、AMQP、MQTT、OpenWire、STOMP。
  • 多种持久化选项:如 KahaDB 和 JDBC。
  • 兼容性:与 Java 生态和 JEE 集成良好。
优点
  • 完全支持 JMS 标准,适合 Java 应用。
  • 协议兼容性强,适用性广。
  • 入门门槛低,部署相对简单。
缺点
  • 性能和吞吐量低于其他主流中间件(约 1 万 TPS)。
  • 消息堆积时性能较差。
  • 扩展性有限,不适合高并发场景。

3. Kafka

简介

Kafka 是分布式流处理平台,专注于高吞吐量和实时数据流处理。

特点
  • 高吞吐量:每秒可处理百万级消息。
  • 分布式架构:支持水平扩展和高可用。
  • 消息持久化:默认持久化,可回溯消费。
  • 流处理支持:内置 Streams API 和 Connect 工具。
优点
  • 高吞吐量,适合大规模数据流处理。
  • 水平扩展能力强,分区机制高效。
  • 持久化默认开启,支持回溯消费。
  • 社区活跃,生态系统丰富。
缺点
  • 学习成本高,配置和运维复杂。
  • 消费模型相对复杂,不支持消息确认机制。
  • 适用于批量处理,低延迟场景表现一般。

4. RocketMQ

简介

RocketMQ 是阿里巴巴开源的分布式消息队列,支持事务消息和延迟队列。

特点
  • 事务支持:支持分布式事务消息。
  • 高吞吐量:优化后的高性能(约 20 万 TPS)。
  • 延迟队列:支持定时或延迟消息投递。
  • 分布式架构:支持水平扩展和高可用。
优点
  • 性能优异,吞吐量高。
  • 支持分布式事务和延迟消息。
  • 与主流大数据技术兼容。
  • 社区支持较好,适合电商和金融场景。
缺点
  • 配置较复杂,运维成本较高。
  • 社区和生态规模小于 Kafka 和 RabbitMQ。
  • 延迟队列功能适用场景有限。

5. Redis(Pub/Sub 模式)

简介

Redis 的 Pub/Sub 提供了轻量级的消息发布与订阅功能,性能优异但功能有限。

特点
  • 轻量级:无需额外配置,即可支持消息队列功能。
  • 实时性:消息延迟极低。
  • 无持久化:Pub/Sub 模式不保存历史消息。
优点
  • 简单易用,零配置即可使用。
  • 极低的消息延迟,性能优异(单实例百万级 TPS)。
  • 适合轻量级实时通信场景。
缺点
  • 无持久化,消息无法回溯。
  • 无高级功能(如消息确认、死信队列)。
  • 消息队列功能较弱,扩展性有限。

6. 对比分析

特性RabbitMQActiveMQKafkaRocketMQRedis(Pub/Sub)
协议支持AMQP、MQTT、STOMPJMS、AMQP、MQTT、STOMP原生协议原生协议、部分支持 JMS
吞吐量中等(~10 万 TPS)较低(~1 万 TPS)高(~百万 TPS)高(~20 万 TPS)极高(单实例百万 TPS)
消息持久化支持,需配置支持,性能较差默认持久化默认持久化不支持
可靠性高,支持确认机制中,可靠性依赖配置高,默认多副本持久化高,支持事务消息较低
延迟中等较高中等极低
扩展性较好,支持集群一般,扩展性有限极强,分布式设计较强较弱
适用场景复杂路由、企业应用小型项目、传统企业应用实时流处理、大数据电商、金融、分布式事务轻量级实时通信

7. 选择建议

  • RabbitMQ:适用于中小型企业需要可靠消息传递和复杂路由的场景,尤其是支持 AMQP 协议的系统。
  • ActiveMQ:适合轻量级 Java 应用集成,需求简单且吞吐量不高的场景。
  • Kafka:是高吞吐量和实时流处理的首选,适用于大数据、日志收集和事件驱动架构。
  • RocketMQ:适合对延迟和性能要求高的场景,如电商订单系统、分布式事务消息。
  • Redis(Pub/Sub 模式):适用于对延迟敏感、功能简单的实时通信场景,如在线聊天、实时通知。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/476843.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VXLAN说明

1. 什么是 VXLAN ? VXLAN(Virtual Extensible LAN,虚拟扩展局域网)是一种网络虚拟化技术,旨在通过在现有的物理网络上实现虚拟网络扩展,从而克服传统 VLAN 的一些限制。 VXLAN 主要用于数据中心、云计算环…

RTL8211F 1000M以太网PHY指示灯

在RK3562 Linux5.10 SDK里面已支持该芯片kernel-5.10/drivers/net/phy/realtek.c,而默认是没有去修改到LED配置的,我们根据硬件设计修改相应的寄存器配置,该PHY有3个LED引脚,我们LED0不使用,LED1接绿灯(数据…

主IP地址与从IP地址:深入解析与应用探讨

在互联网的浩瀚世界中,每台联网设备都需要一个独特的身份标识——IP地址。随着网络技术的不断发展,IP地址的角色日益重要,而“主IP地址”与“从IP地址”的概念也逐渐进入人们的视野。这两个术语虽然看似简单,实则蕴含着丰富的网络…

【Redis】基于Redis实现秒杀功能

业务的流程大概就是,先判断优惠卷是否过期,然后判断是否有库存,最好进行扣减库存,加入全局唯一id,然后生成订单。 一、超卖问题 真是的场景下可能会有超卖问题,比如开200个线程进行抢购,抢100个…

计算机网络socket编程(4)_TCP socket API 详解

个人主页:C忠实粉丝 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C忠实粉丝 原创 计算机网络socket编程(4)_TCP socket API 详解 收录于专栏【计算机网络】 本专栏旨在分享学习计算机网络的一点学习笔记,欢迎大家在评论区交流讨论&…

Jmeter数据库压测之达梦数据库的配置方法

目录 1、概述 2、测试环境 3、数据库压测配置 3.1 安装jmeter 3.2 选择语言 3.3 新建测试计划 3.4 配置JDBC连接池 3.5 配置线程组 3.6 配置测试报告 3.7 执行测试 1、概述 Jmeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试。 它最…

RAG与微调:大模型落地的最佳路径选择(文末赠书)

一、大模型技术发展现状 自2022年底ChatGPT掀起AI革命以来,大语言模型(LLM)技术快速迭代发展,从GPT-4到Claude 2,从文心一言到通义千问,大模型技术以惊人的速度发展。然而,在企业实际应用场景中…

Web 入门

HTTP 一、概念 Hyper Text Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。 二、特点 基于TCP协议:面向连接,安全。基于请求-响应模型的:一次请求对应一次响应。HTTP协议是无状态的协…

pinia是什么?pinia简介快速入门,创建pinia到vue3项目中

一,pinia就是Vuex,的替代工具,Vuex plus 如何将pinia引入到vue3项目中? 1.首先新建一个vue3项目 全填yes npm init vuelatest 2.安装好之后查阅官方文档 pinia使用文档 3.从而得知在项目中有俩种方式安装pinia 我的本地只有nod…

Java 基于SpringBoot+vue框架的老年医疗保健网站

大家好,我是Java徐师兄,今天为大家带来的是Java Java 基于SpringBootvue框架的老年医疗保健网站。该系统采用 Java 语言开发,SpringBoot 框架,MySql 作为数据库,系统功能完善 ,实用性强 ,可供大…

FPGA实现串口升级及MultiBoot(九)BPI FLASH相关实例演示

本文目录索引 区别一:启动流程的区别区别二:高位地址处理区别三:地址映射例程说明总结例程地址之前一直都是以SPI FLASH为例进行相关知识讲解,今天我们介绍另一款常用的配置FLASH-BPI FLASH。 今天的讲解以简洁为主,主打个能用一句话不说两句话。以和SPI区别为主,实例演…

VisionPro 机器视觉案例 之 彩色保险丝个数统计

第十四篇 机器视觉案例 之 彩色保险丝颜色识别个数统计 文章目录 第十四篇 机器视觉案例 之 彩色保险丝颜色识别个数统计1.案例要求2.实现思路2.1 方法一 颜色分离工具CogColorSegmenterTool将每一种颜色分离出来,得到对应的单独图像,使用斑点工具CogBlo…

实时数据研发 | Flink技术栈

下周要开始接触一些实时的内容了,想来是很幸运的,这是我在新人培训上提问过技术前辈的问题:“想学习实时相关技术,但是部门没有类似的需求,应该如何提升?”当时师姐说先用心去学,然后向主管证明…

Spring cloud 一.Consul服务注册与发现(4)

1.动态刷新案例步骤 1.问题 接着上一步,我们在consul的dev配置分支修改了内容马上访问,结果无效 会发现还是原来的内容,/(ㄒoㄒ)/~~ ,没有做到及时响应和动态刷新 2.步骤 RefreshScope主启动类添加 package com.atguigu.cloud;import org.springfram…

石油化工调度台的外观如何设计更有科技感

在石油化工行业中,调度台作为生产运营的核心指挥中枢,其设计不仅关乎操作效率,更是企业形象和技术实力的体现。那么,到底如何在调度台的外观设计中融入科技感,以提升工作效率并彰显企业前沿形象,成为了一个…

【机器学习】——朴素贝叶斯模型

💻博主现有专栏: C51单片机(STC89C516),c语言,c,离散数学,算法设计与分析,数据结构,Python,Java基础,MySQL,linux&#xf…

如何使用Jest测试你的React组件

在本文中,我们将了解如何使用Jest(Facebook 维护的一个测试框架)来测试我们的React组件。我们将首先了解如何在纯 JavaScript 函数上使用 Jest,然后再了解它提供的一些开箱即用的功能,这些功能专门用于使测试 React 应…

Stm32f103X HAL库 串口DMA空闲中断学习 踩坑记

捡 了一个Stm32f103X的工控板, 开发工具是 STM32cubeide ,复制了之前闲的时候建的一个485通讯的空工程,只配置了圈中的引脚,用的是usart3 ,增加了需要用的io,编程器是网上几块钱买的jlink-ob,带模拟串口的. 在学习串口通信的过程中总感觉不太顺利 ,刚开始用串口中断…

云服务器部署WebSocket项目

WebSocket是一种在单个TCP连接上进行全双工通信的协议,其设计的目的是在Web浏览器和Web服务器之间进行实时通信(实时Web) WebSocket协议的优点包括: 1. 更高效的网络利用率:与HTTP相比,WebSocket的握手只…

PDF内容提取,MinerU使用

准备环境 # python 3.10 python3 -m pip install huggingface_hub python3 -m pip install modelscope python3 -m pip install -U magic-pdf[full] --extra-index-url https://wheels.myhloli.com下载需要的模型 import json import osimport requests from huggingface_hub…