- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否有任何标准方法来控制 MDB 中的并发和消耗?我能找到的每个建议似乎都是特定于应用程序服务器或资源适配器的(例如 maxSession @ActivationConfigProperty
)。
问题™
我们在双节点 JBoss 设置 (EAP 6.3) 上运行一些相对繁重的分析作业,并希望并行化作业并对并发作业数量施加上限,这样我们就不会淹没数据库服务器。作业从 Web 前端启动,并且应该在有空闲处理槽时启动 - 没有优先级或排序限制。我们使用消息队列(IBM WMQ,因为政治原因)将“开始分析”消息分发到节点。
现在的进展
在遵循各种建议进行大量摆弄之后,结果证明是非工作资源适配器特定的 Cargo-Cult Misinformation™ :),我 思想 通过为 MDB 定义 EJB 池解决了该问题。这确实解决了并发问题,但不幸的是,似乎没有空闲 MDB 的节点仍会拉取队列中的消息 - 这可能会使一个节点未得到充分利用而另一个节点满载积压。
如果我明白 IBM documentation正确地,这种行为应该可以通过 来控制允许预读 配置选项,但这似乎根本不影响我的结果。
那么,有没有:
UPDATE Projects SET Status='inprogress' WHERE Id=42 AND Status='inqueue';
的方式进行操作。 - 但如果我不需要,我宁愿不去那里,主要是因为更改队列所需的更改请求:)
最佳答案
MQ 和 JMS 的设计和优化旨在尽可能快地将消息传递到管道中。每条消息的状态由队列管理器跟踪,但并发要求将要求 QMgr 跟踪彼此相关的消息状态。 MQ 不这样做。
在调整激活规范连接池和事务范围中有一些粒度,但这些旨在影响服务器的动态行为,而不是精确指定它。
跨多个消息管理应用程序状态正是 IBM Integration Broker 等 ESB 产品的设计目的。 MQ 是一种仅查看消息头以执行路由和交付的传输,而 ESB 则查看消息关系和内容。除非 JMS 规范定义了并发管理 API,否则这种由 MQ 负责传输和 ESB 负责处理的职责分工不太可能改变。
不管是用ESB还是JEE代码实现的,你描述的都是Message Dispatcher Pattern来自 Enterprise Integration Patterns书,消息传递世界中权威的架构引用之一。有几种方法可以编写它,具体取决于对仪器的偏好。
代币化
GET
在 token 队列和同步点下等待。 PUT
s 相同的消息回到 token 队列,再次在同步点下。 GET
等待同步点下的应用程序队列。 COMMIT
或 ROLLBACK
作为适当的。 {max outstanding message limit}
进行比较在调度程序应用程序的配置中设置。 GET
s 一条消息,它还向调度员的 ACK
发送一条消息队列,同步点下的两个操作。 COMMIT
调度程序收到 ACK 并递减未完成消息计数器。 关于jakarta-ee - 在 MDB 中控制并发和消耗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33651654/
我想了解为什么一些 Jakarta EE 规范是空的。 例如 Jakarta Annotations规范由免责声明和快速描述(3 行)组成,但是有 Javadoc . 当 JCP 负责 J2EE 规范
我们将在我们的开发中使用 WebSphere 8.0 应用服务器。 我们的网络应用程序使用 Amazon aws java sdk,而后者又使用 Apache http-client 4.1。 但是
Java EE Web Profile 认证服务器(如 JOnAS)和 Java EE Full Platform 认证服务器(如 JBoss AS)有什么区别? 最佳答案 这是一张很好的图片来解释它
Java EE 5 和 Java EE 6 的主要区别是什么? 最佳答案 Oracle 有一篇由三部分组成的文章详细介绍了这些更改:Introducing the Java EE 6 Platform
自从我将 web.xml 从 Java-EE-5 迁移到 Java-EE-6 后,我的应用程序出现问题。这是我部署应用程序时得到的堆栈跟踪: 24 août 2011 14:10:45 org.apa
我想让我的 Java EE 应用程序可插入。主应用程序将部署在一个ear 中,但它在EJB 中的代码将包含插件的入口点。插件可以部署在它们自己的 jar 文件中。有什么好的框架可以做到这一点吗?我正在
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我有一个关于 EE 容器如何控制事务的问题。这是为我的问题提供一些上下文的伪代码。这不是我编码的方式,所以请留在问题上,不要将主题演变成其他内容。 考虑以下两个服务和相关 Controller 。这两
如果在应用程序初始化期间发生异常,是否有任何方法可以防止 Java EE 应用程序启动?在从 JSR-77 抛出未处理的异常之后,我基本上是在寻找一种方法来使应用程序进入“j2ee.state.fai
我们正在开发几个独立的应用程序/模块,我们将它们部署到 Glassfish 3.1.1 应用程序服务器上。在某些情况下,这些应用程序需要通过远程接口(interface)调用彼此的方法。打包这些远程接
我对 Java 有所了解,但对 Enterprise Java 完全陌生。我正在尝试使用 NetBeans 6.1 和 GlassFish Application Server。 请指导我一些资源,这
这个问题在这里已经有了答案: Java / Jakarta EE web development, where do I start and what skills do I need? [close
我有现有的Java EE Web应用程序。我还有一个新的Grails 1.3.7应用程序。 要求是将此Grails应用程序嵌入现有Java EE应用程序中,并将其部署在一个war文件中。请让我知道是否
我熟悉 LAMP 堆栈,多年来已经成功部署了一些基于它的网络站点。我使用过从 Apache + modPerl 到 PHP、Ruby 和 Rails 的一切。通过充分利用缓存,我的 Rails 站点可
这个问题已经有答案了: What exactly is Java EE? (6 个回答) 已关闭 8 年前。 我意识到它的字面意思是Java Enterprise Edition。但我要问的是,这到底
我当前在服务器上有一个 Java EE 应用程序。它使用struts2和Hibernate。我需要访问客户端计算机并搜索客户端计算机检测到的所有蓝牙外设的MAC地址。 那么问题是:如何访问客户端计算机
我们在 StatelessSessionBean 中有一个性能不佳的业务方法。为了提高性能,我们希望将此业务方法拆分为多个异步方法调用。 问题是这些异步方法必须在同一个事务中运行(它们必须使用同一个
希望使用 JSTL 和 Apache Torque 以及某种模板引擎来扩展当前的 Java EE 项目,以便我们可以轻松修改 View 。 有什么建议? 最佳答案 我想 Freemarker是领先的
我有一个在 tomcat 上运行的非常大的 Java EE 应用程序。不幸的是,最近我遇到了堆空间和内存泄漏错误。 所以我想知道是否有一个工具可以帮助我监控我的应用程序并给我一个每个对象的可视化展示,
这个问题在这里已经有了答案: What exactly is Java EE? (6 个答案) 关闭 4 年前。 我知道这个问题已经被问了一百万次,我也做了功课,但最后一件事我不完全理解的是,是否有
我是一名优秀的程序员,十分优秀!