- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我们有一个使用消息驱动 bean 处理 JMS 消息的应用程序。此应用程序部署在 OC4J 应用程序服务器上。 (10.1.3)
我们计划在多个 OC4J 应用程序服务器上部署此应用程序,这些服务器将被配置为在集群中运行。
问题出在这个集群中的 JMS 消息处理上。我们必须确保在整个 OC4J 集群中一次只处理一条消息。这是必需的,因为必须按时间顺序处理消息。
您是否知道可以控制跨 OC4J 集群的消息处理的配置参数?
或者您认为我们必须实现自己的同步代码来同步集群中的消息驱动 bean?
最佳答案
我结合使用竞争消费者模式和租赁模式,在集群中对消息进行了大规模的顺序处理 - 每天 150 万多条消息。
不过,问题来了 - 您一次只能处理一个交易的要求将使您无法实现自己的目标。我们有相同的基本要求——必须按顺序处理消息。至少,我们认为我们做到了。然后我们有了一个顿悟——当我们对这个问题进行更多思考时,我们意识到我们不需要完全排序。我们实际上只需要在每个帐户内订购。因此,我们可以通过将帐户范围分配给集群中的不同服务器来在集群中的服务器之间分配负载。然后,每个服务器负责按顺序处理给定帐户的消息。
这是第二个聪明的部分 - 我们使用租用模式动态地将帐户范围分配给集群中的各个服务器。如果集群中的一台服务器出现故障,另一台将抢占租约并接管第一台服务器的责任。
这对我们很有效,并且该流程在生产中使用了大约 4 年,之后因公司合并而被替换。
编辑:
我在这里更详细地解释了这个解决方案:http://coders-log.blogspot.com/2008/12/favorite-projects-series-installment-2.html
编辑:
好的,明白了。您已经在您需要的级别进行处理,但是由于您正在部署到一个集群,您需要确保只有一个 MDB 实例正在主动从队列中拉取消息。另外,您需要最简单可行的解决方案。
我认为您不需要放弃现有的 MDB 机制。本质上我们在这里讨论的是对分布式锁机制的需求,而不是花言巧语。
所以,让我提出这个建议。在您的 MDB 注册接收来自队列的消息时,它应该检查分布式锁,看看它是否可以获取它。第一个获取锁的 MDB 获胜,只有它会注册接收消息。所以,现在你有了序列化。这个锁应该采用什么形式?有很多可能性。好吧,这个怎么样。如果您有权访问数据库,那么它的事务锁定已经提供了您所需要的一些功能。创建一个只有一行的表。该行是当前持有锁的服务器的标识符和过期时间。这是服务器的租约。每个服务器都需要有一种方法来生成其唯一标识符,例如,可能是服务器名称加上线程 ID。
如果服务器可以获得对该行的更新访问权,并且租约已过期,则它应该获取它。否则,它会放弃。如果它获得了租约,它需要在不久的将来更新该行,比如五分钟左右,然后提交更新。 Activity 服务器应在租期到期前更新租约。我建议在剩余一半时间时更新它,因此,如果租约在五天后到期,则每 2-1/2 分钟更新一次。这样,您现在就可以进行故障转移了。如果 Activity MDB 死亡,另一个 MDB(并且只有一个)将接管。
我认为这应该非常简单。现在,您想让 hibernate 的 MDB 偶尔检查锁以查看它是否已释放。
因此, Activity 的 MDB 和 hibernate 的 MDB 都必须定期执行某些操作。您可能让他们生成一个单独的线程来执行此操作。如果您这样做,许多应用程序引擎供应商会不高兴,但是添加一个线程没什么大不了的,尤其是因为它大部分时间都在 hibernate 。另一种选择是结合许多引擎提供的计时器机制,并让它定期唤醒您的 MDB 以检查租约。
哦,顺便说一句 - 确保服务器管理员使用 NTP 来保持时钟合理同步。
关于java - 确保在 OC4J 集群中串行处理 JMS 消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1411066/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!