当前位置: 首页 > article >正文

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

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

 

 

点对点消息队列(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等。

 

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


http://www.kler.cn/news/309782.html

相关文章:

  • sql刷题常用函数
  • 微博计算架构实战
  • 【Android 13源码分析】WindowContainer窗口层级-1-初识窗口层级树
  • 【车载开发系列】ParaSoft单元测试环境配置(三)
  • 【原创】java+springboot+mysql高校社团网系统设计与实现
  • 【数据库】MySQL-基础篇-多表查询
  • 赋值运算符
  • 用Kimi输出流程图
  • MybatisPlus的一点了解
  • 深入Redis:分布式锁
  • [语言月赛 202408] 因友情而终结
  • 深圳国际VR/AR博览会圆满落下帷幕
  • 【C++ Primer Plus习题】16.8
  • yaml注入配置文件
  • 【ZYNQ】OV5640 图像采集与显示
  • 【Linux】权限理解(超详细)
  • 【与C++的邂逅】--- C++的IO流
  • sqlgun靶场训练
  • 【机器学习】--- 自然语言推理(NLI)
  • SPI软件模拟读写W25Q64
  • Qt常用控件——QLCDNumber
  • scantf
  • Linux--守护进程与会话
  • Java 中 List 常用类和数据结构详解及案例示范
  • 基于python+django+vue的外卖管理系统
  • java循环遍历树状结构对象并转换成另外树状结构对象
  • 6.安卓逆向-安卓开发基础adb工具
  • 学习贵在善假于物
  • 什么是科技与艺术相结合的异形创意圆形(饼/盘)LED显示屏
  • YooAsset基础操作及热更