美文网首页
消息队列中点对点与发布订阅

消息队列中点对点与发布订阅

作者: 爱情小傻蛋 | 来源:发表于2019-09-29 16:55 被阅读0次

JMS一个在 Java标准化组织(JCP)内开发的标准(代号JSR 914)。2001年6月25日,Java消息服务发布JMS 1.0.2b,2002年3月18日Java消息服务发布 1.1.

Java消息服务(Java Message Service,JMS)应用程序接口是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。

点对点与发布订阅最初是由JMS定义的。这两种模式主要区别或解决的问题就是发送到队列的消息能否重复消费(多订阅)

1.JMS中定义

JMS规范目前支持两种消息模型:点对点(point to point, queue)和发布/订阅(publish/subscribe,topic)。

  • 点对点

消息生产者生产消息发送到queue中,然后消息消费者从queue中取出并且消费消息。这里要注意:

消息被消费以后,queue中不再有存储,所以消息消费者不可能消费到已经被消费的消息。

Queue支持存在多个消费者,但是对一个消息而言,只会有一个消费者可以消费。

  • 发布/订阅

消息生产者(发布)将消息发布到topic中,同时有多个消息消费者(订阅)消费该消息。和点对点方式不同,发布到topic的消息会被所有订阅者消费。

2.二者分析与区别

2.1 点对点

生产者发送一条消息到queue,只有一个消费者能收到

2.2 发布/订阅

发布者发送到topic的消息,只有订阅了topic的订阅者才会收到消息。

2.3 小结

queue实现了负载均衡,一个消息只能被一个消费者接受,当没有消费者可用时,这个消息会被保存直到有 一个可用的消费者,一个queue可以有很多消费者,他们之间实现了负载均衡, 所以Queue实现了一个可靠的负载均衡。 topic实现了发布和订阅,当你发布一个消息,所有订阅这个topic的服务都能得到这个消息,所以从1到N个订阅者都能得到一个消息的拷贝, 只有在消息代理收到消息时有一个有效订阅时的订阅者才能得到这个消息的拷贝。

2.4 疑问

发布订阅模式下,能否实现订阅者负载均衡消费呢?当发布者消息量很大时,显然单个订阅者的处理能力是不足的。实际上现实场景中是多个订阅者节点组成一个订阅组负载均衡消费topic消息即分组订阅,

这样订阅者很容易实现消费能力线性扩展。

image

3 流行消息队列的消息模型比较

传统企业型消息队列ActiveMQ遵循了JMS规范,实现了点对点和发布订阅模型,但其他流行的消息队列RabbitMQ、Kafka并没有遵循老态龙钟的JMS规范,是通过什么方式实现消费负载均衡、多订阅呢?

3.1 RabbitMQ

RabbitMQ实现了AQMP协议,AQMP协议定义了消息路由规则和方式。生产端通过路由规则发送消息到不同queue,消费端根据queue名称消费消息。此外RabbitMQ是向消费端推送消息,订阅关系和消费状态保存在服务端。

image

生产端发送一条消息通过路由投递到Queue,只有一个消费者能消费到。

image

当RabbitMQ需要支持多订阅时,发布者发送的消息通过路由同时写到多个Queue,不同订阅组消费此消息。
RabbitMQ既支持内存队列也支持持久化队列,消费端为推模型,消费状态和订阅关系由服务端负责维护,消息消费完后立即删除,不保留历史消息。所以支持多订阅时,消息会多个拷贝。

3.2 Kafka

Kafka只支持消息持久化,消费端为拉模型,消费状态和订阅关系由客户端端负责维护,消息消费完后不会立即删除,会保留历史消息。因此支持多订阅时,消息只会存储一份就可以了。

image

同一个订阅组会消费topic所有消息,每条消息只会被同一个订阅组的一个消费节点消费,同一个订阅组内不同消费节点会消费不同消息。

相关文章

  • Java高频面试集-消息队列MQ

    学习 1、MQ消息队列分类有哪些? 消息队列分类:点对点和发布/订阅两种: 1.1、点对点: 支持此模式:rabb...

  • 分布式-5-JMS

    JMS(Java Message Service) API规范 模式点对点发布订阅 点对点 组成消息队列(Queu...

  • 消息队列中点对点与发布订阅

    JMS一个在 Java标准化组织(JCP)内开发的标准(代号JSR 914)。2001年6月25日,Java消息服...

  • MQ

    1. 消息队列的通信模型 点对点模式 发布/订阅 2.kafka使用场景 消息队列 追踪网站活动 Metrics(...

  • 消息队列中点对点与发布订阅区别

    1.JMS定义 JMS规范支持两种消息模型:点对点(point to point, queue)和发布/订阅(pu...

  • 消息队列一

    消息队列有两种模式,一种是队列模式,一种订阅-发布模式. 队列模式就是一个点对点,生产者生产消息发入到队列,然后消...

  • 【kafka学习笔记】了解消息队列

    kafka是什么 你可以将它作为消息队列使用,点对点或者发布订阅的模式都可以。 你也可以将它作为消息引擎使用,实现...

  • kafka整体介绍

    消息队列意义及缺点 意义 异步处理,提高吞吐量 服务解耦 削峰填谷,流量控制 支持点对点、发布/订阅不同消息模型 ...

  • RabbitMQ简介

    RabbitMQ是一种消息队列 ,用于常见的进程通信。支持点对点,请求应答和发布订阅模式 并且提供多种语言的支持。...

  • 消息队列

    一、消息模型 点对点模型:消息生产者向队列中发送一个消息后,只能被一个消费者消费未命名文件.png 发布/订阅:生...

网友评论

      本文标题:消息队列中点对点与发布订阅

      本文链接:https://www.haomeiwen.com/subject/rdtqpctx.html