【ActiveMQ入门-5】ActiveMQ学习-Queue与Topic的比较

QueueTopic的比较



1、JMS Queue执行load balancer语义:

一条消息仅能被一个consumer收到。

如果在message发送的时候没有可用的consumer,那么它将被保存一直到能处理该message的consumer可用。

如果一个consumer收到一条message后却不响应它,那么这条消息将被转到另一个consumer那儿。

一个Queue可以有很多consumer,并且在多个可用的consumer中负载均衡。



如何理解:如果一个consumer收到一条message后却不响应它,那么这条消息将被转到另一个consumer那儿。

见附件中的程序:

在Receiver.java中, 创建了消费者并实现了同步接收:


  1. while (true) {
  2. // 设置接收者接收消息的时间,为了便于测试,这里谁定为100s
  3. TextMessage message = (TextMessage) consumer.receive(18000);
  4. // Object message = (Object) consumer.receive(28000);
  5. if (null != message) {
  6. System.out.println("订阅者1:收到消息-->" + message.getText());
  7. } else {
  8. System.out.println("订阅者1:运行结束...\n");
  9. break;
  10. }
  11. }

在Receiver2.java中,创建了消费者但是注释掉了接收部分的程序:


  1. //while (true) {
  2. // // 设置接收者接收消息的时间,为了便于测试,这里谁定为100s
  3. // TextMessage message = (TextMessage) consumer.receive(18000);
  4. // if (null != message) {
  5. // System.out.println("订阅者2:收到消息-->" + message.getText());
  6. // } else {
  7. // System.out.println("订阅者2:消费者运行结束...\n");
  8. // break;
  9. // }
  10. // }

先分别将Receiver和Receiver2运行起来,然后再运行Sender,将得到如下运行结果:

特别注意:订阅者2在订阅者1之后停止运行,如何在订阅者1前停止运行,结果还不一样。

此时再次开启receive1,将看到:

如果订阅者2在订阅者1之前停止运行,将会出现如下运行结果:




2、Topic实现publish和subscribe语义:

一条消息被publish时,它将发到所有感兴趣的订阅者,所以零到多个subscriber将接收到消息的一个拷贝。但是在消息代理接收到消息时,只有激活订阅的subscriber能够获得消息的一个拷贝。



3、分别对应两种消息模式:

Point-to-Point (点对点),Publisher/Subscriber Model (发布/订阅者)

其中在Publicher/Subscriber 模式下又有Nondurable subscription(非持久订阅)和durable subscription (持久化订阅)2种消息处理方式。

来自为知笔记(Wiz)

附件列表

时间: 2024-10-28 22:11:36

【ActiveMQ入门-5】ActiveMQ学习-Queue与Topic的比较的相关文章

【ActiveMQ入门-11】ActiveMQ学习-compositeDestination

概要: 前一章讲解了消费者如何通过通配符来匹配目的地,以实现一个消费者同时接收多个目的地的消息. 对于生产者来讲,可能存在下面的需求: 1. 同一条message可能要发送到多个Queue: 2. 同一条message同时发送到Queue和Topic:等 这时,我们可以使用composite Destination来解决. 官方文章:http://activemq.apache.org/composite-destinations.html 下面将介绍如何将message发送到多个Queue.以

【ActiveMQ入门-5】ActiveMQ学习-消息持久性

ActiveMQ中的消息持久性     ActiveMQ很好的支持了消息的持久性(Persistence).消息持久性对于可靠消息传递来说应该是一种比较好的方法,有了消息持久化,即使发送者和接受者不是同时在线或者消息中心在发送者发送消息后宕机了,在消息中心重新启动后仍然可以将消息发送出去,如果把这种持久化和ReliableMessaging结合起来应该是很好的保证了消息的可靠传送. 消息持久性的原理很简单,就是在发送者将消息发送出去后,消息中心首先将消息存储到本地数据文件.内存数据库或者远程数据

消息中间件-ActiveMQ入门实例

1.下载ActiveMQ: http://activemq.apache.org/download-archives.html 2.运行ActiveMQ 解压缩apache-activemq-5.5.1-bin.zip,然后双击apache-activemq-5.5.1\bin\win64\activemq.bat运行ActiveMQ程序.注意:期间若遇到无法启动的情况,请尝试将计算机名改为全英文,不能有其他字符!启动以后可浏览器打开一下网址登录,以便后面查看后面程序运行以后的信息!包括消息队列

ActiveMQ 入门Nodejs版

ActiveMQ 入门下载与安装 官方下载地址 解压,运行bin/win[32|64]/activemq[.bat] 启动服务 环境信息 控制台: http://localhost:8161 默认端口:8161 服务地址: host: localhost port: 61613 代码例子 基本信息: 语言:Node.js 客户端:stompjs 消息发布者: 复制代码 Queue消息消费者 // Consumer_queue.js var Stomp = require('stompjs');

ActiveMQ入门案例以及整合Spring的简单实用

先来个ActiveMQ介绍哈: MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法,是一个消息中间件. 应用场景:为了实现系统之间的通信,把系统之间的调用耦合度降低就可以使用MQ. 1) activeMQ 是Apache出品,最流行的,能力强劲的开源消息总线. 2) avtiveMQ主要特点:完全支持JMS1.1和J2EE 1.4规范:支持spring,很容易内嵌到spring中:支持ajax. 3) activeMQ的消息形式: a) 点对点形式,即生产

ActiveMQ入门介绍

1.JMS简介 JMS的全称是Java Message Service,即Java消息服务.它主要用于在生产者和消费者之间进行消息传递,生产者负责产生消息,而消费者负责接收消息.把它应用到实际的业务需求中可以在特定的时候利用生产者生成消息,并进行发送,对应的消费者在接收到对应的消息后去完成对应的业务逻辑.对于消息的传递有两种类型,一种是点对点的,即一个生产者和一个消费者一一对应:另一种是发布/订阅模式,即一个生产者产生消息并进行发送后,可以由多个消费者进行接收. JMS编程模型 (1) Conn

ActiveMQ入门系列二:入门代码实例(点对点模式)

在上一篇<ActiveMQ入门系列一:认识并安装ActiveMQ(Windows下)>中,大致介绍了ActiveMQ和一些概念,并下载.安装.启动他,还访问了他的控制台页面. 这篇,就用代码实例说下如何实现消息的生产和消费. 一.理论基础 同RabbitMQ一样,ActiveMQ中也是有两种模式: 点对点模式(Point to Point,简写为PTP) 发布/订阅模式(Publish & Subscribe,简写为Pub & Sub) 通过上一篇我们知道了制造消息的应用叫生产

ActiveMQ入门实例

1.下载ActiveMQ 去官方网站下载:http://activemq.apache.org/ 2.运行ActiveMQ 解压缩apache-activemq-5.5.1-bin.zip,然后双击apache-activemq-5.5.1\bin\activemq.bat运行ActiveMQ程序. 启动ActiveMQ以后,登陆:http://localhost:8161/admin/,创建一个Queue,命名为FirstQueue. 3.创建Eclipse项目并运行 创建project:Ac

.Net平台下ActiveMQ入门实例

1.ActiveMQ简介 先分析这么一个场景:当我们在网站上购物时,必须经过,下订单.发票创建.付款处理.订单履行.航运等.但是,当用户下单后,立即跳转到“感谢那您的订单” 页面.不仅如此,若果没有延迟,用户还会受到一封电子邮件.如果我们使用传统方式去实现,一般是对数据库操作一通,然后调用各种接口.各种服务等待各种响应,这样一来下个订单需要很久时间才能看到结果,如果某个环节出了问题,那这个订单结果一时半会是看不到了,对于现代电子商务来说,这是不能容忍的. 那么ActiveMQ久可以很好的解决这个