消息中间件有哪些常见类型

消息中间件根据其设计理念和用途,可以大致分为以下几种常见类型:

点对点消息队列(Point-to-Point Messaging Queues):

在这种模型中,消息被发送到特定的队列中,消费者从队列中取出并处理消息。队列中的消息只能被一个消费者消费,消费后即被删除。

常见的实现包括IBM的MQSeries、RabbitMQ的部分使用场景等。

适用于任务分发、负载均衡等场景。

发布/订阅消息模型(Pub/Sub Messaging):

在发布/订阅模型中,消息被发布到特定的主题(Topic)上,所有订阅了该主题的消费者都可以接收到这个消息。

消息不会从主题中删除,除非它被设置为持久化且被明确删除,或者消息中间件根据策略自动删除旧消息。

常见的实现有RabbitMQ(通过Exchange实现)、Apache Kafka、Google Cloud Pub/Sub等。

适用于广播消息、事件通知等场景。

消息代理(Brokered Messaging):

消息代理是一种更通用的概念,它涵盖了上述的点对点和发布/订阅模型,以及可能的其他消息传递模式。

消息代理作为消息的存储和转发中心,负责消息的路由、过滤、持久化等功能。

大多数现代消息中间件都可以被视为消息代理,如RabbitMQ、ActiveMQ、Apache Kafka等。

分布式消息队列(Distributed Messaging Queues):

分布式消息队列是为了满足大规模分布式系统的高可用性、可扩展性和容错性需求而设计的。

它们通常将消息存储在多个节点上,支持节点的自动发现和故障转移。

Apache Kafka是一个典型的分布式消息队列系统,它还支持流式处理。

基于日志的消息系统(Log-based Messaging Systems):

这类消息系统使用日志结构来存储消息,提供了极高的吞吐量和可扩展性。

它们通常将消息作为有序的记录追加到日志文件中,并支持高效的读取和复制操作。

Apache Kafka是这一类型的典型代表。

轻量级消息队列(Lightweight Messaging Queues):

轻量级消息队列通常用于较小的系统或微服务架构中,以提供简单的消息传递功能。

它们可能不支持所有高级特性,但具有较小的资源占用和较快的启动速度。

示例包括ZeroMQ、NanoMsg等。

需要注意的是,这些类型并不是严格互斥的,有些消息中间件可能支持多种消息传递模式或结合了多种类型的特点。在选择消息中间件时,需要根据具体的应用场景和需求进行综合考虑。

相关推荐
一嘴一个橘子16 分钟前
mybatis - 动态语句、批量注册mapper、分页插件
java
组合缺一17 分钟前
Json Dom 怎么玩转?
java·json·dom·snack4
危险、33 分钟前
一套提升 Spring Boot 项目的高并发、高可用能力的 Cursor 专用提示词
java·spring boot·提示词
kaico201838 分钟前
JDK11新特性
java
钊兵38 分钟前
java实现GeoJSON地理信息对经纬度点的匹配
java·开发语言
jiayong2343 分钟前
Tomcat性能优化面试题
java·性能优化·tomcat
秋刀鱼程序编程1 小时前
Java基础入门(五)----面向对象(上)
java·开发语言
纪莫1 小时前
技术面:MySQL篇(InnoDB的锁机制)
java·数据库·java面试⑧股
Remember_9931 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
Filotimo_1 小时前
在java开发中,cron表达式概念
java·开发语言·数据库