我的目的是列出Java应用程序中一组MQ队列中消息的关联ID。
这是代码段
public void populateCorrelationIds() throws MQException{
int openOptions = MQConstants.MQOO_INPUT_AS_Q_DEF | MQConstants.MQOO_OUTPUT | MQConstants.MQOO_INQUIRE | MQConstants.MQOO_BROWSE;
String qNames[0] = BAY10.CISCHGX.DFDA;
String qNames[1] = BAYSF11.MSFCHGX.DFDA;
MQMessage messageGet = new MQMessage();
for(String q : qNames){
MQQueue dfdaQ = qMgr.accessQueue(q, openOptions);
MQGetMessageOptions gmo = new MQGetMessageOptions();
gmo.options = MQConstants.MQGMO_BROWSE_FIRST| MQConstants.MQGMO_WAIT;
gmo.waitInterval = 4000;
int j = dfdaQ.getCurrentDepth();
for(int i=0;i<j;i++)
{
dfdaQ.get(messageGet,gmo); //Error generated here when getting message for qNames[1]
byte[] correlId= messageGet.correlationId;
}
}
}
以下是我得到的错误 -
MQJE001: Completion Code '2', Reason '2033'. com.ibm.mq.MQException:
MQJE001: Completion Code '2', Reason '2033'. at
com.ibm.mq.MQDestination.getInt(MQDestination.java:655) at
com.ibm.mq.MQDestination.get(MQDestination.java:459) at
Utility.populateCorrelationIds(Utility.java:152) at
Utility.main(Utility.java:64) MQJE001: Completion Code '2', Reason '2033'.
这是我运行代码时遇到的错误。请注意,当我从队列中获取下一个队列的消息时,会发生错误。我成功地能够浏览第一个队列的所有消息。但是当我在第二个队列中浏览第一条消息时,我得到了上述错误。任何人都可以帮助解决此错误。
答案 0 :(得分:4)
这里有几点需要注意:
第一个是因为您在第一个MQMessage
循环之外初始化for
个对象。它必须位于第二个for
循环内,因为当MessageId
调用返回时,MQ会使用CorrelationId
,MQQueue.get
,消息正文填充该对象。如果使用相同的get
对象实例再次调用MQMessage
,则实际上是在尝试使用先前检索到的消息的MessageId来获取消息。此调用失败,带有2033原因代码。
关于您的代码还有其他几点。
1)您必须在第二个new MQGetMessageOptions()
循环中执行for
。
2)您正在使用BROWSE_FIRST选项。这将仅浏览第一条消息。要浏览所有邮件,您必须使用get
选项BROWSE_NEXT
。当您打开队列时,浏览光标在逻辑上位于队列中的第一条消息之前。这意味着,如果您在get
电话后立即拨打accessQueue
电话,则可以使用MQGMO_BROWSE_NEXT
选项浏览第一条消息;您不必使用MQGMO_BROWSE_FIRST
选项
3)如果仅为browse
打开队列,则无需指定MQConstants.MQOO_OUTPUT | MQConstants.MQOO_INQUIRE
打开选项。
4)getCurrentDepth()方法在调用时返回队列深度。当您的应用程序正在浏览时,某些其他应用程序可能会从同一队列中获取消息。在这种情况下,当前队列深度将发生变化,但不会通知您的应用程序更改。因此,您可以在dfdaQ.getCurrentDepth()
循环中使用MQGMO_BROWSE_NEXT
选项,而不是使用while
。当没有要浏览的消息时,get调用将返回2033原因代码。您可以检查此原因代码并退出while循环。