- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我是 Message Queue 的新手。我正在尝试使用以下代码从 MQ 队列获取消息。
我正在创建一个连接并使用该连接从队列中获取每条消息。这样做是否正确以及我是否需要提交连接。
无限循环是一直从队列接收消息的正确方法,对吗?请给我建议。
try {
createMQConnection(); // getting mq connection
createMQSession(); // getting mq session
createMQDestination(); // getting mq destination
for ( ; ; ) { // infinite loop to receive message from Queue
consumer = session.createConsumer(mqQueue);
jmsTextMessage = (JMSTextMessage) consumer.receive(100);
// Calling application method to process the requested message from queue
}
} catch (Exception e) {
throw e;
} finally {
// closing consumer
// closing session
// closing connection
}
最佳答案
Is it right way of doing like this
定义“正确”。根据业务需求,这可能是正确的,也可能很糟糕。例如,如果等待时间为 100 毫秒且消息深度为零,则代码将超时、抛出 2033 错误 (MQRC_NO_MSG_AVAILABLE)、关闭 session 并退出。这是你想要的吗?
通常有一个 try
/catch
block 包含 GET
并处理 transient 错误,如 RC=2033
如果意图是程序在队列为空时仍保持运行。但在那种情况下,通常将超时设置为 10 秒左右。在 100 毫秒超时的情况下,如果将编写的应用程序修改为保持运行状态,那么它绝对会影响监听器。
此外,异常处理不显示任何用于打印链接异常的代码。 JMS 异常是多级数据结构,其中传输提供商的 native 错误代码位于异常的链接部分。如果错误处理不查看链接的异常,它甚至无法区分 MQRC=2033
(无消息)与 MQRC=2035
(授权错误)之间的区别。其中一个是短暂的,应该由程序幸存下来,另一个总是致命的。至少,代码应该打印链接异常或者打印一条消息,说明没有找到链接异常。
因此关于循环和处理设计,在不知道需求的情况下不可能回答“正确”的值。关于异常处理,绝对不是正确的,因为不存在链接的异常处理。
...and whether I need to commit the connection.
视情况而定。丢失或重复消息是否可以?如果是这样,则不需要交易。使用事务处理 session 可以防止消息丢失,但不能防止重复。使用 XA 2-Phase Commit 可以防止消息丢失和欺骗。这个想法是选择满足业务需求和相应编码的服务类别(通常称为“至多一次”、“至少一次”或“一次且仅一次”)。
Infinite for-loop is right way to receive messages all the times from the queue, is it right?
这是一种方法。对于高可用性和高吞吐量,通常有两个或更多应用程序实例在同一队列上监听。这样,如果一个应用程序服务器实例出现故障(无论是计划内还是计划外),其他实例将继续为队列提供服务。一般而言,所有这些实例都会在大约 10 秒的超时时间内监听队列。
通常,队列上的 GET
指定 MQGMO_FAIL_IF_QUIESCING
,这允许 QMgr 在 MQ 管理员尝试关闭 QMgr 时中断应用程序。如果未指定此选项,则关闭 QMgr 的唯一方法是要求它强行断开未完成的连接,这只能作为最后的手段。
当消息到达队列时,也可能导致 MQ 触发应用程序启动。当应用程序在 JEE 服务器上运行时,通常不会这样做,但对于独立应用程序非常有用。
关于java - Websphere MQ 消息无限进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41825830/
我们目前使用 MQ Explorer 来管理 Z/OS 上的 WebSphere MQ V7。前几天误删了一个队列。后来我想回顾一下历史并查看一些日志以了解它究竟发生在何时。我的问题是,MQ Expl
默认情况下是否安装了扩展事务客户端?如何验证是否已安装?我如何安装这个? 最佳答案 在先前版本的 MQ 客户端中,它当然不包含在标准客户端中(事务客户端具有成本/许可影响)。 但是,从 WMQ v7.
我有 2 个队列,比如 Q1 和 Q2。当我使用 MQPUT 将消息插入 Q1 时,有什么方法可以将此消息复制到 Q2 中吗? WMQ 是否支持队列复制? 注意:队列驻留在不同的队列管理器上。 谢谢,
我有一个进程,它使用 JMSTemplate 根据 JMS header 值有选择地从 MQ 队列中出列。 当出队查询匹配队列前面的消息时,出队速率约为 60-70 条消息/秒。但是,当查询仅匹配 5
Source LogPrimaryFiles=3|2-254 (Windows)|2-510 (UNIX systems) The log files allocated when the queue
在Websphere MQ系列中,队列管理器的命令级别是701。它实际上指定了什么? 最佳答案 WebSphere 产品使用“[版本].[发行版].[修改].[修订包]”命名约定。例如,7.0.1.6
在哪里可以找到 IBM MQ 版本 V8.0.0.5 和 V9.0 之间的区别?我试图在 IBM 网站上查找它,但没有成功。 最佳答案 IBM 的 v9 知识中心页面“What's new in Ve
我已经在我的机器上安装了 MQ(已经用 regedit32 检查过)但是当我在命令提示符下键入“runmqsc”时出现错误“无法识别命令”(为 mqjms.jar 设置了环境变量)我是什么失踪 ?我想
我在我的系统中安装了 MQ V8.0.0.2,我正在应用修复包以使用静默安装方法将其升级到 8.0.0.5。它运行成功并完成,但 dspmqver仍然说版本为 8.0.0.2。 它在 64 位的 Wi
我们有一个场景,我们希望 node.js 应用程序使用来自后端系统的消息,该后端系统当前将消息放入 Websphere MQ 队列(通过 SAP PI)。 在 MQ 8.0.0.3 中,有一个 AMQ
我们有消息通过 WebSphere MQ 队列传入。我们需要很长时间才能收到消息。 是否有一种简单易行的方法来跟踪收到/提取消息的时间? 最佳答案 发送消息后,您可以请求确认交货。当消息被消费时,一条
我想将文件系统中的文件加载到 WebSphere MQ 队列。有几个支持 pacs - Q Program和 MO03: WebSphere MQ Queue Load / Unload Utilit
有人使用过 RPG 中的 MQ 吗?问题如下。队列中有几条消息。它们都带有 RFH2 header 。每个 header 都包含一组 NameValueData。我正在创建消息句柄并将其传递给 MQG
我有一组 IBM MQ 队列管理器,想知道其中一个何时重新启动或何时自动故障转移到备用实例。 队列管理器位于 AIX 上 问候, 最佳答案 您可以从 AMQERR01.LOG 中找到此信息。队列管理器
作为我们应用程序安装的一部分,我需要将一堆 xml 消息放入一个 MQ 队列中。为了使它更复杂,消息需要设置 RFH2 header 的 usr 文件夹。 我发现 mqput2.exe来自 IBM R
我一直在研究变幻莫测的 channel 状态、它们如何进入这些状态以及如何停止或启动它们。我现在已经有了相当扎实的理解,但是一位同事提出了 channel 重置的话题。 当我无法解释发生了什么时,我偶
我从 MQ 安全演示文稿中看到一项建议,如果您不需要命令服务器,它会关闭它。我的问题是如何确定我是否真的需要它。 从我的角度来看,如果没有运行目标 QMGR 的管理程序,例如 MQ Explorer
是否可以保留已检索且不再位于队列中的消息历史记录(包含消息内容将是完美的)? 在应用程序中,我可以看到发送者何时尝试将消息放入队列以及接收者何时尝试拾取消息,但我想查看消息何时真正到达队列以及消息何时
有没有办法找到在特定时间段内通过 IBM websphere MQ 队列管理器的消息总数? 最佳答案 这听起来像是 MQ 记帐和统计功能的完美使用。除此之外,这些功能还记录消息数量(具有持久和非持久计
我正在向远程队列发送消息,但我无法控制该队列。 我发送一个 xml 文件作为消息,但是当应用程序读取消息时,它会得到一个消息头,例如 jms_text \0\0\0lqueue:///TEST128
我是一名优秀的程序员,十分优秀!