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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/369346.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android 对称加密和非对称加密,Android开发加密之对称与非对称加密算法使用案例.pdf...

Android开发加密之对称与非对称加密算法使用案例消息摘要md5:登录注册, sha1对称加密 1.des:Data Encryption Standard,数据加密标准 2.aes:Advanced Encryption Standard ,更高级的方式对称加密特点:加…

unity 半透明混合问题_Unity 实时 半透明 阴影 shader

简单阴影制作思路:1:在角色脚底 放置一块平板2:shader中 根据平板传入的矩阵 以及 光照 对角色进行变换3: 得到投影在地面上的阴影4:阴影直接渲染到 屏幕上缺点:上面的阴影无法 增加半透明阴影效果&#xf…

Showplan 逻辑运算符和物理运算符参考

本文档已存档,并且将不进行维护。运算符说明了 SQL Server 如何执行查询或数据操作语言 (DML) 语句。 查询优化器使用运算符生成查询计划,以创建在查询中指定的结果或执行在 DML 语句中指定的操作。 查询计划是由物理运算符组成的一个树。 您可以使用 SE…

在win10中通过Anaconda3安装tensorflow

安装Anaconda3,然后在所有程序中启动“Anaconda Navigator”,如图: 切换到“Enviroments"(环境)中,在右边有个显示环境的列表,默认有"base(root)",然后单击底部的”Create"按钮创建一个…

ddr5内存上市时间_DDR5内存明年才能上市,SK Hynix已预研DDR6:12Gbps

拼 命 加 载 中 ... 随着去年Q4季度DRAM芯片价格开始下跌,DDR4内存的价格已经有了松动,很多人还期待着8GB内存降回200多元的价格呢。现在的DDR4内存已经有了继任者——DDR5,标准及芯片生产都完成了,不过尚无平台支持,最快今年底才会有DDR5内存上市,更多地还是2020年上市。…

功能接口简介–在Java 8中重新创建的概念

世界各地的所有Java开发人员都将至少使用以下接口之一:java.lang.Runnable,java.awt.event.ActionListener,java.util.Comparator,java.util.concurrent.Callable。 声明的接口之间有一些共同的特征,该特征是它们在接口…

计算机专业职业规划范文800字,计算机专业学生职业生涯规划书

作为一名计算机学生,这门专业比较难学,所以在进入大学后,我必须得为自己做一份职业生涯规划,让自己在大学几年里能完成学业,成功的奔赴社会工作。一、自我分析我虽然是自己选的计算机专业,但是兴趣并不是很…

Python核心模块——urllib模块

urllib模块中的方法 1.urllib.urlopen(url[,data[,proxies]]) 打开一个url的方法,返回一个文件对象,然后可以进行类似文件对象的操作。本例试着打开google >>> import urllib >>> f urllib.urlopen(http://www.google.com.hk/) >&…

HTML 中点击a标签,页面跳转执行过程

HTML链接使用的是<a>标签点击超链接,后台的执行大致如下:<a href"https://www.baidu.com">超链接</a>根据链接地址看出,执行的是https协议点击超链接,首先在本地的hosts文件(C:\Windows\System32\drivers\etc\hosts)中查找是否有与网址匹配的ip如果…

JS中原型与原型链

一. 普通对象与函数对象 JavaScript 中&#xff0c;万物皆对象&#xff01;但对象也是有区别的。分为普通对象和函数对象&#xff0c;Object 、Function等 是 JS 自带的函数对象。下面举例说明。 var o1 {}; var o2 new Object(); var o3 new f1();function f1(){}; var f2…

计算机专业学生求职信500字,计算机专业求职信500字范文

计算机专业求职信500字范文尊敬的领导&#xff1a;您好&#xff01;请恕打扰&#xff0c;我是荆楚理工学院计算机工程学院的一个大学生&#xff0c;即将面临毕业.我很荣幸有机回向您呈上我的个人资料.在投身社会之际,为了找到符合自己专业和兴趣的工作,更好地发挥自己的才能,实…

一年中所有节日的排列顺序_计数问题(二)-排列组合的使用

在计数问题(一)中我们分析了排列和组合的定义&#xff0c;计算方法以及公式的含义。排列组合的基本定义讲述的是从一列元素中分先后&#xff08;排列&#xff09;或不分先后地选出部分元素&#xff0c;其可能的选择方法数。在这一期中我们会更仔细地分析组合的公式的含义&#…

使用Spring数据和Thymeleaf实现Bootstrap分页

Twitter Bootstrap具有非常好的分页UI &#xff0c;在这里我将向您展示如何使用Spring Data Web分页功能和Thymeleaf条件评估功能来实现它。 引导程序中的标准分页 受Rdio启发的简单分页&#xff0c;非常适合应用程序和搜索结果。 大块很难错过&#xff0c;易于扩展&#xff0…

一道前端学习题

对于没参加过互联网企业招聘&#xff0c;或是没有参加过大型互联网企业招聘的人来说&#xff0c;能以这些公司的面试题做为锻炼&#xff0c;无疑是一种非常好的学习和进步的途径。下面是一道腾讯的前端面试题(JS解答)&#xff0c;题目本身在现实中意义不大&#xff0c;主要是考…

codefroces 297E Mystic Carvings

problem&#xff1a;一个圆上依次有1~2*n的数字。每个数字都有且只有另一个数字与他相连。选出三条线&#xff0c;使得每条线的两端之间隔的最少点(只包括被选择的6个点)的个数相等。输入输出格式输入格式&#xff1a;The first line contains integer n(3<n<10^5) — th…

连接计算机和网络传输介质的接口,最常用的网络传输介质和连接设备

T型连接器与BNC接插件是细同轴电缆的连接器&#xff0c;它对网络的可靠性有着重要的影响。同轴电缆与T型连接器是依赖于BNC接插件进行连接的。BNC接插件有手工安装和工具型安装之分&#xff0c;用户可根据实际情况和线路的可靠性选择。RJ&#xff0d;45非屏蔽双绞线连接器有8根…

监听网页微信扫码支付成功_网付扫码点餐新福利,消费者点餐可获微信支付金币奖励...

扫码点餐相信大家都不陌生&#xff0c;即能餐饮解决商家人力物力投入成本痛点&#xff0c;又能方便消费者点餐。现今已成为了餐饮商户的标配系统。近两年&#xff0c;很多系统厂商都在试水扫码点餐领域。尤其是聚合支付服务商&#xff0c;拥有得天独厚的优势。市面上各家扫码点…

在Play上使用twitter4j! 框架和安全社交很容易

在昨天的个人黑客马拉松期间&#xff0c;我启动了一个项目&#xff0c;我可能会在这里介绍。 但是&#xff0c;最酷的启示是&#xff08;再次&#xff09;启动和运行起来有多么容易。 创建一个新的Play项目 添加Secure Social并为Twitter配置它&#xff0c;并使用示例中的InM…

Python 冒泡排序三种写法

需求&#xff1a;输入 n 个整数并将这些数字以从大到小和从小到大的顺序输出代码如下&#xff1a;bubble_sort_v1 1 #coding:utf-82 #__author__ Diva3 4 # 升序&#xff08;从小到大&#xff09;5 SORT_TYPE_ASC 16 # 降序&#xff08;从大到小&#xff09;7 SORT_TYPE_DE…

前端程序员容易忽视的一些基础知识

基础数据结构与算法 现在有两个不同的JSON&#xff0c;比较复杂&#xff0c;可以参考这里的DEMO中返回的JSON。要比较它们的差异&#xff0c;除了用现成的工具如 beyond compare以外&#xff0c;如果我们的机器上没有安装这个工具&#xff0c;能如何较快解决&#xff1f;作为一…