0

我在 Weblogic 上有一个分布式队列。使用 JMS onMessage() 函数从队列中读取消息。但是,只要部署正在运行,消息就不会从队列中清除。消息状态字符串始终为“接收”。我们如何确保在重新启动部署的情况下不会再次拾取消息?

  @Override
public void onMessage(Message msg) {
    try {
        String msgText;
        if (msg instanceof TextMessage) {
            msgText = ((TextMessage) msg).getText();
        } else {
            msgText = msg.toString();
        }

       System.out.println("Message Received from Message_RESPONSE_QUEUE: " + msgText + " - " + count++);

        // now send the message to queue2
        InitialContext ic2 = getInitialContext2();
        getMsgFromQueue qs = new getMsgFromQueue();
        qs.init2(ic2, QUEUE2);
        qs.send(msg, null);

    } catch (JMSException jmse) {
    } catch (NamingException ex) {
        Logger.getLogger(getMsgFromQueue.class.getName()).log(Level.SEVERE, null, ex);
    }
}
4

1 回答 1

0

在 JMS 服务器收到确认之前,不会删除来自 JMS 队列的消息。

以下是一些您可能会觉得有用的参考资料 -

http://docs.oracle.com/cd/E17904_01/web.1111/e15493/prog_details.htm#i1156227

http://docs.oracle.com/cd/E17904_01/web.1111/e15493/prog_details.htm#i1152248

http://docs.oracle.com/cd/E17904_01/web.1111/e15493/prog_details.htm#i1156227

于 2014-10-16T09:34:52.330 回答