验证应用程序

时间:2018-01-08 07:50:50

标签: java jms activemq message-queue messaging

我使用JMS(Fiorano提供程序)作为两个应用程序之间的同步。 App-A将在主题上发布消息,App-B有任何数据更改,以便App-B可以更新其状态。

现在我面临的问题是App-A发送的所有消息都没有被App-A读取,因此两个应用程序之间存在数据不一致。

这是背景故事!谢谢你,如果你到目前为止已阅读它..

以下是我的问题:

  1. 有没有办法获取App-A发布的所有未被App-B读取的消息列表

  2. App-b无法阅读少量消息的根本原因是什么?

  3. 请帮我解决这个问题。

1 个答案:

答案 0 :(得分:0)

如果您想知道消费者是否传递或使用了消息,您必须使用ActiveMQ Advisory Messages。 在生产者方面,您订阅了相应的目的地,以便收到每条消费消息的通知,但您必须保留已发送消息的更新列表,以了解哪些消息尚未消费...

如果消息冻结,app-b可能无法读取消息......

如果您希望AMQ丢弃一段时间后未处理的消息,您可以使用 JMSExpiration

  

消息到期的时间(以毫秒为单位)。值0表示永不过期。   http://activemq.apache.org/activemq-message-properties.html

http://activemq.apache.org/advisory-message.html

以下是代码的基本示例:

import java.util.HashSet;
import java.util.Set;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.ActiveMQSession;
import org.apache.activemq.command.ActiveMQMessage;
import org.apache.activemq.command.MessageId;

public class AdvisorySupportGetMessageConsumedAdvisoryTopic {

    public static void main(String[] args) throws JMSException {
        final Set<MessageId> sentMessages = new HashSet<MessageId>();
        Connection conn = null;
        try {
            ConnectionFactory cf = new ActiveMQConnectionFactory();
            conn = cf.createConnection();
            ActiveMQSession session = (ActiveMQSession) conn.createSession(false,
                    ActiveMQSession.AUTO_ACKNOWLEDGE);
            conn.start();
            Queue q = session.createQueue("q");
            Destination advisoryDestination = org.apache.activemq.advisory.AdvisorySupport
                    .getMessageConsumedAdvisoryTopic(q);
            MessageConsumer consumer = session.createConsumer(advisoryDestination);
            consumer.setMessageListener(new MessageListener() {
                @Override
                public void onMessage(Message msg) {
                    System.out.println(msg);
                    System.out.println(((ActiveMQMessage) msg).getMessageId());
                    sentMessages.remove(((ActiveMQMessage) msg).getMessageId());
                }
            });
            MessageProducer advisoryProducer = session.createProducer(q);
            TextMessage resp = session.createTextMessage("text");
            advisoryProducer.send(resp);
            sentMessages.add(((ActiveMQMessage) resp).getMessageId());
            System.out.println(((ActiveMQMessage) resp).getMessageId());
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (conn != null) {
                try {
                    conn.close();
                } catch (Exception e) {
                }
            }
        }
    }
}