常用消息中间件

RocketMQ

阿里开源,阿里参照kafka设计的,Java实现

能够保证严格的消息顺序

提供针对消息的过滤功能

提供丰富的消息拉取模式

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

实时的消息订阅机制

亿级消息堆积能力

RabbitMQ

Erlang实现,非常重量级,更适合于企业级的开发。同时实现了Broker架构,核心思想是生产者不会将消息直接发送给队列,消息在发送给客户端时先在中心队列排队。对路由(Routing),负载均衡(Load balance)、数据持久化都有很好的支持

ActiveMQ

Apache下的子项目,java实现,少量代码就可以高效地实现高级应用场景

Redis

可以当做一个轻量级的队列服务来使用,c语言实现

实验证明:入队时,当数据比较小时Redis的性能要高于RabbitMQ,而如果数据大小超过了10K,Redis则慢的无法忍受;出队时,无论数据大小,Redis都表现出非常好的性能,而RabbitMQ的出队性能则远低于Redis

Kafka

Apache下的一个子项目,使用scala实现的一个高性能分布式Publish/Subscribe消息队列系统

快速持久化:通过磁盘顺序读写与零拷贝机制,可以在O(1)的系统开销下进行消息持久化;

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

高堆积:支持topic下消费者较长时间离线,消息堆积量大;

完全的分布式系统:Broker、Producer、Consumer都原生自动支持分布式,依赖zookeeper自动实现复杂均衡;

支持Hadoop数据并行加载:对于像Hadoop的一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案

ZeroMQ

号称最快的消息队列系统,专门为高吞吐量/低延迟的场景开发,在金融界的应用中经常使用,偏重于实时数据通信场景

仅提供非持久性的队列,如果down机,数据将会丢失

相关推荐
人活一口气5 小时前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还7 小时前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP8 小时前
vibe Coding -- 小项目实战
java
未秃头的程序猿13 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户2986985301414 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉14 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯14 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手14 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记14 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码14 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python