activemq 持久订阅

因此,您希望使用ActiveMQ跨分布式主题进行发布-订阅,并且要可靠。 您可以使用永久订阅,对吗? 可以,但是,如果您将群集与ActiveMQ一起使用,则可能会遇到意外的行为。 我最近在一个客户端上,我注意到了这一行为,并且还注意到在使用Weblogic JMS集群时也存在相同的行为。 那么问题是什么,ActiveMQ可以解决什么问题呢? 好吧,我假设您已经读过标题,所以您可能有个主意……但我还是会继续前进……

考虑这种情况。 您有经纪人A和经纪人B。它们在两个方向上都联网在一起,形成一个完全网格类型的经纪人网络 。 又名,群集。 然后,您将使用故障转移URL failvoer:(tcp://hostA,tcp://hostB)拥有一个订户FOO。 这意味着订阅者将从故障转移传输中的节点列表中随机选择一个URL,然后连接到该代理。 到目前为止,一切都很好。 假设故障转移URL选择了要连接的代理B,并且订阅者在代理B上创建了对主题TEST.TOPIC的持久订阅。在TEST.TOPIC ,代理网络将确定B上有一个新的TEST.TOPIC 。因此,如果经纪人A上有任何生产者,那么经纪人A应该将消息转发给经纪人B(消费者在哪里)。

现在让我们说订户FOO决定断开与代理B的连接。这是很好的,因为这是持久预订,因此消息应保留,并且如果订户FOO返回,则它应该能够检索传递到主题TEST.TOPIC任何消息。 TEST.TOPIC不在时。 但是,如果订户FOO使用故障转移传输直接连接到代理A,会发生什么? 最终将创建一个新的持久订阅(它不会使用与网络创建的持久订阅相同的..,因为该用户与网桥相关联),但是它将无法访问代理中可能存在的任何消息B.当制片人发送更多的消息给A,它也将尝试着给经纪人B的是在那里用户原是 。 现在想象一下可以连接,断开连接并重新连接到集群中不同代理的多个订户。 您最终将因订阅泄漏而到处丢失消息。 uck 这同样适用于真实的故障情况,在这种情况下,订户FOO不会自愿断开连接,而是代理B崩溃,而订户FOO被迫重新连接到代理A。您仍然会丢失消息。

好吧,事实证明,这种行为在具有分布式主题的Weblogic服务器和集群JMS服务器上也存在(大致相当于我上面描述的代理网络)。 那么,我们将不能可靠地进行分布式发布订阅吗? 好吧,我不确定WLS如何解决它,但是ActiveMQ有一个很棒的解决方案叫做Virtual Topics 。 对于分布式pup-sub来说,这是一个很棒的功能,但即使在单代理部署中,它也克服了持久订阅者的限制。

有什么限制?

考虑这一点…您正在使用主题TEST.TOPIC.的持久订阅者TEST.TOPIC. 事实证明,对消息的处理要花很长时间,因此您希望让另一个订户在同一消息通道上侦听以“平衡”工作负载。 试试吧。 您会很快发现JMS规范不允许这样做,因为持久订阅者必须具有唯一的clientIddurableName并且不能有多个订阅者在侦听相同的消息流。

那么,您如何在池化连接的应用程序服务器中部署订户。 您正在尝试在多个持久订户之间共享连接。 好了,您将再次遇到持久订阅者clientId和持久名称的限制。

因此,回到我们的分布式发布订阅问题。 如果使用虚拟主题,则可以解决我上面描述的问题。 虚拟主题在幕后使用队列(对于消费者来说……请阅读虚拟主题上的Apache文档,它有一些很棒的示例),使用队列,您可以将消息重播给您(例如,当订户重新连接到A时,它是消息不会丢失,因为可以重播消息),或者如果B代理由于某种原因而发生故障(失败),则可以让一个从属服务器在其位置等待重播否则可能丢失的消息。 有关更多详细信息,请查看有关具有持久订阅者的分布式主题的ActiveMQ常见问题解答,因为我现在就开始编写它。

参考: ActiveMQ群集,持久订阅者和虚拟主题,可从Christian Posta Software博客的JCG合作伙伴 Christian Posta那里抢救出来。

翻译自: https://www.javacodegeeks.com/2013/02/activemq-clustering-durable-subscribers-and-virtual-topics-to-the-rescue.html

activemq 持久订阅

activemq 持久订阅_ActiveMQ群集,持久订阅者和虚拟主题可助您一臂之力相关推荐

  1. ActiveMQ群集,持久订阅者和虚拟主题可助您一臂之力

    因此,您希望跨分布式主题使用ActiveMQ进行发布-订阅,并且要可靠. 您可以只使用永久订阅,对不对? 可以,但是,如果将群集与ActiveMQ一起使用,则可能会遇到意外行为. 我最近在一个客户端上 ...

  2. activemq消息持久化_ActiveMQ 5.x中的消息持久性

    activemq消息持久化 我被问了很多关于ActiveMQ如何存储消息(或在某些情况下不存储)的基本知识. 这是它的高级解释. 注意,上下文在JMS中. 如果您使用ActiveMQ的非JMS客户端( ...

  3. activemq网络桥接_ActiveMQ –经纪人网络解释–第5部分

    activemq网络桥接 在前面的第4部分中,我们已经看到了如何使用网络连接器在队列中平衡远程使用者的负载. 在第5部分中,如果主题上同时存在多个远程持久订阅者,我们将看到相同的配置如何工作. 考虑以 ...

  4. Redis 笔记(10)— 发布订阅模式(发布订阅单个信道、订阅信道后的返回值分类、发布订阅多个信道)

    1. 发布-订阅概念 发布-订阅 模式包含两种角色,分别为发布者和订阅者. 订阅者可以订阅一个或者若干个频道(channel): 而发布者可以向指定的频道发送消息,所有订阅此频道的订阅者都可以收到此消 ...

  5. python redis订阅_python实现 redis订阅与发布

    订阅者可以订阅一个或多个频道,发布者向一个频道发送消息后,所有订阅这个频道的订阅者都将收到消息,而发布者也将收到一个数值,这个数值是收到消息的订阅者的数量.订阅者只能收到自它开始订阅后发布者所发布的消 ...

  6. 【EventBus】事件通信框架 ( 订阅方法注册 | 检查订阅方法缓存 | 反射获取订阅类中的订阅方法 )

    文章目录 一.检查订阅方法缓存 二.反射获取订阅类中的订阅方法 三.完整代码示例 一.检查订阅方法缓存 注册订阅者时 , 只传入一个订阅者类对象 , 其它信息都需要通过反射获取 ; 1. 获取订阅者类 ...

  7. mysql之间互相订阅_mysql – 开票和订阅的应用程序逻辑?

    我们正处于为客户提供订阅的网络应用程序的规划阶段.订阅期有所不同,可以由我们的客户无限期延长,但始终至少一个月(30天). 当客户注册时,客户信息(账单地址,电话号码等)存储在客户表中,并在订阅表中创 ...

  8. php苹果支付订阅付费_比较订阅,按错误付费和咨询软件业务模型

    php苹果支付订阅付费 在今年的FOSS Backstage,我主持了关于开源模型的讨论,并分享了为什么我认为订阅是支持开源产品的好方法. 选择一种商业模式 我与他人共同创立的公司Nextcloud仅 ...

  9. iOS 自动续期订阅,订阅升级降级、订阅时间、退收费处理

    自动续期订阅群组设置概述 设置自动续期订阅与设置其他 App 内购买项目类型不同.每个自动续期订阅产品需创建为订阅群组的一部分并为其分配等级.您对订阅群组的设置将决 定顾客如何订阅您的内容或服务.如何 ...

最新文章

  1. SAP MM PIR里的Lower Limit Upper Limit
  2. vs2017c语言单元测试,vs2017单元测试没反应,检测出错误,有关详细信息,请查看“测试输出”窗口...
  3. 数据结构Java02【栈、队列、单链表(增删节点)、循环链表、双向循环链表、递归(斐波那契、汉诺塔)】
  4. JavaScript 转载
  5. Pytorch:损失函数
  6. 计算机在线作业office,全国计算机一级office题库与答案
  7. 软件测试基础概念(二)测试环
  8. IAP固件升级原理及实现详解
  9. 一个简单T9输入法的实现
  10. 智牛股_第6章_Mybatis Generator代码生成器
  11. 原理剖析(第 006 篇)Semaphore工作原理分析
  12. 图像特征提取(颜色,纹理,形状)
  13. 利用公网IP访问部署在阿里云服务器的spring boot项目(一)
  14. jmeter学习:成功发帖纪录
  15. 人工智能肺炎图像识别模型-企业模型_科研机构应用
  16. IDE、PCI、ISA、SCSI的区别
  17. Java文件怎么打开?Java后缀的文件打开方式
  18. 通过keil编译明白自己的程序占用的内存大小。堆栈大小分配,32单片机片内存储flash的使用。
  19. CAD入门学习教程:用CAD软件计算面积时如何转换单位?
  20. 【附源码】计算机毕业设计SSM特大城市地铁站卫生防疫系统

热门文章

  1. JavaScript学习总结(九)——Javascript面向(基于)对象编程
  2. Spring Boot 集成 Mybatis 实现双数据源
  3. 尽力去帮助一个陌生人
  4. 充电提示音_iPhone如何自定义充电提示音,图文教程
  5. Linux 退出保存/不保存
  6. 将字符串String str= “abc god 中国 java“ 反转每个单词 结果: “cba dog 国中
  7. excel趋势线公式导出_如何用Excel进行预测分析?
  8. for in for of区别_(for…in) VS (for…of)
  9. python绘图时的分解问题的步骤-零基础学python-15.2 分解函数
  10. 405: HTTP method GET is not supported by this URL