一,非持久订阅者 和 实时消费消息

这篇文章中区分了Domain为Pub/Sub、Destination为Topic时,消费者有两种:持久订阅者 和 非持久订阅者。

对于持久订阅者而言,只要订阅了某个Topic,就不用担心自己“离线”(inactive)后,错过某些消息。

但是对于非持久订阅者:①生产者发送了若干个消息到Topic后,非持久订阅者才去订阅该Topic,则它会错过(收不到)在它订阅之前发送的消息。

②生产者向Topic发送了若干个消息,而此时因网络中断原因或者非持久订阅者宕机时,非持久订阅者刚好不在线(inactive),就会错过(收不到)生产者发送的消息。

③从消息的角度而言,有些消息是实时消息(如,实时股票价格),需要快速地消费掉,对消息进行持久化就没有太大的意义,而且会因为存储消息而造成一定的开销。

因此,为了提高非持久订阅者的可靠性,以及实时的消费消息,就需要:❶消息不进行持久化并缓存消息(Caching message for nondurable consumers);❷对缓存的消息的消费策略

二,Retroactive Consumers

什么是Retroactive Consumer呢?

Retroactive Consumer属于非持久订阅者,但它是消费 持久化消息 的订阅者。(其他非持久订阅者 可以消费持久化消息)

The ActiveMQ message broker caches messages in memory for every topic that is used.
The only types of topics that are not supported are temporary topics and ActiveMQ advisory topics.
Messages that are cached by the broker are only dispatched to a topic consumer if it is retroactive;and never to durable topic subscribers.

①ActiveMQ Broker可以为各种Topic缓存消息(但不支持 temporary topic 和 advisory topic)。这说明:该机制只针对Topic而言。

②缓存的消息只会发给 retroactive consumer,并不会发送给持久订阅者。

那非持久订阅者如何成为 retroactive consumer呢?最简单的方式是在创建Topic的时候指定consumer为retroactive

Topic topic = session.createTopic("soccer.division1.leeds?consumer.retroactive=true");
MessageConsumer consumer = session.createConsumer(topic);

三,消息“订阅恢复策略”(Subscription Recovery Policies)

正因为 retroactive consumer 消费的是非持久化的消息(消息保存在内存中),所以就会出现 第一部分中提到的这两个问题:

①生产者发送了若干个消息到Topic后,非持久订阅者才去订阅该Topic,则它会错过(收不到)在它订阅之前发送的消息。

②生产者向Topic发送了若干个消息,而此时因网络中断原因或者非持久订阅者宕机时,非持久订阅者刚好不在线(inactive),就会错过(收不到)生产者发送的消息。

就需要:订阅恢复策略。订阅恢复策略的目的就是让retroactive consumer能够回到过去某个时间点消费它错过了的消息。

比如说:生产者发送了消息A,消息B给Broker的Topic之后,retroactive consumer才订阅该Topic,订阅恢复策略就可以让retroactive consumer能收到在它订阅之前就已经发送的消息(消息A 和消息B)

订阅恢复策略主要有以下几类,简要介绍如下:(具体的配置参数可参考官网)

1)FixedSizedSubscriptionRecoveryPolicy

这是ActiveMQ默认的策略。该恢复订阅策略最大的特点是:开辟多大的内存缓存发送到该Topic的消息。

2)Fixed Count Subscription Recovery Policy

按照数量来缓存消息。即,允许Topic最大缓存多少条消息。举例如下:

假设设置的Topic最大可缓存1000条消息。当前Topic已经缓存了500条消息了,retroactive consumer在 收到了一些消息之后宕机了,在宕机这段时间内,生产者又向Topic发送了100条消息。那么当retroactive consumer恢复正常后,生产者又向Topic发送了200条消息,那么:retroactive consumer 首先会收到它宕机期间错过的100条消息,然后就收到刚刚的200条消息。(总的消息条数未超过1000)

.....

还有其他一些恢复订阅策略就不一 一介绍了。总之,恢复订阅策略针对的是非持久化的retroactive consumer订阅者而言的。它提高了非持久化消息的可靠性。

四,参考资料:

ActiveMQ消息传送机制以及ACK机制详解

《ActiveMQ in Action》

ActiveMQ官网

JMS学习(六)--提高非持久订阅者的可靠性 以及 订阅恢复策略的更多相关文章

  1. JMS学习六(ActiveMQ消息传送模型)

    ActiveMQ 支持两种截然不同的消息传送模型:PTP(即点对点模型)和Pub/Sub(即发布 /订阅模型),分别称作:PTP Domain 和Pub/Sub Domain. 一.PTP消息传送模型 ...

  2. JMS学习(六)-ActiveMQ的高可用性实现

    原文地址:http://www.cnblogs.com/hapjin/p/5663024.html 一,ActiveMQ高可用性的架构 ActiveMQ的高可用性架构是基于Master/Slave 模 ...

  3. JMS学习(五)--ActiveMQ中的消息的持久化和非持久化 以及 持久订阅者 和 非持久订阅者之间的区别与联系

    一,消息的持久化和非持久化 ①DeliveryMode 这是传输模式.ActiveMQ支持两种传输模式:持久传输和非持久传输(persistent and non-persistent deliver ...

  4. JMS学习七(ActiveMQ之Topic的持久订阅)

    非持久化订阅持续到它们订阅对象的生命周期.这意味着,客户端只能在订阅者活动时看到相关主题发布的消息.如果订阅者不活动,它会错过相关主题的消息.如果花费较大的开销,订阅者可以被定义为durable(持久 ...

  5. ActiveMQ queue和topic,持久订阅和非持久订阅

    消息的 destination 分为 queue 和 topic,而消费者称为 subscriber(订阅者).queue 中的消息只会发送给一个订阅者,而 topic 的消息,会发送给每一个订阅者. ...

  6. JMS学习一(JMS介绍)

    一.JMS是个什么鬼 1.百度百科解释:JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之 ...

  7. 消息队列-推/拉模式学习 & ActiveMQ及JMS学习

    一种分类是推和拉 . 还有一种分类是 Queue 和 Pub/Sub . 先看的这一篇:http://blog.csdn.net/heyutao007/article/details/50131089 ...

  8. ActiveMQ基本详解与总结& 消息队列-推/拉模式学习 & ActiveMQ及JMS学习

    转自:https://www.cnblogs.com/Survivalist/p/8094069.html ActiveMQ基本详解与总结 基本使用可以参考https://www.cnblogs.co ...

  9. Jms学习篇一:JMS介绍

    1.JMS介绍: JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API JMS是一种与厂商无关的 API,用来访问 ...

随机推荐

  1. debug 在windows下的使用

    debug是什么? debug是一款windows和DOS系统下的一款软件,其最早可追溯到1937年的"马克1号"(具体度娘):早期debug主要在DOS和windows系统中,它 ...

  2. python 连接 hive 的 HiveServer2 的配置坑

    环境: hadoop 2.7.6 hive 2.3.4 Hive 的 thirft 启动: hadoop 单机或者集群需要: 启动 webhdfs 修改 hadoop 的代理用户 <proper ...

  3. Git版本库的创建(Ubuntu)

    在Ubuntu上学习Git随笔. 一. git 仓库的安装 git 在终端用git命令查看Ubuntu是否安装git版本库,如果没有安装,最新版本(Ubuntu18.04)会提示用下面命令进行安装. ...

  4. 基于tensorflow使用全连接层函数实现多层神经网络并保存和读取模型

    使用之前那个格式写法到后面层数多的话会很乱,所以编写了一个函数创建层,这样看起来可读性高点也更方便整理后期修改维护 #全连接层函数 def fcn_layer( inputs, #输入数据 input ...

  5. sqlserver批量删除字段 msrepl_tran_version

    屁话不多说. 原因: msrepl_tran_version由于有非空约束.所以不能直接删除. --###############################################--1 ...

  6. Call actvity after viewpager is finished

    private OnPageChangeListener mListener = new OnPageChangeListener() { @Override public void onPageSe ...

  7. maven util 类 添加 service

    直接关键代码: public class DictionaryUtil { // 以下的处理,是为了在工具类中自动注入service // 前提是在applicationContext.xml中,将该 ...

  8. 数据库——SQL数据连接查询

    连接查询 查询结果或条件涉及多个表的查询称为连接查询SQL中连接查询的主要类型     广义笛卡尔积     等值连接(含自然连接)     自身连接查询     外连接查询 一.广义笛卡尔积 不带连 ...

  9. Leetcode题库——46.全排列

    @author: ZZQ @software: PyCharm @file: permute.py @time: 2018/11/15 19:42 要求:给定一个没有重复数字的序列,返回其所有可能的全 ...

  10. SpringMVC(三)-- springmvc的系统学习之数据的处理,乱码及restful

    资源:尚学堂 邹波 springmvc框架视频 一.提交数据的处理 1.提交的域名称和处理方法的参数一致 (1)提交的数据:http://localhost:8080/data/hello.do?na ...