StatisticsPlugin中“大小”的值始终为0

时间:2020-03-12 10:32:36

标签: jms activemq

我正在使用ActiveMQ 5.15.11,并且我正在尝试使用StatisticsPlugin插件以编程方式获取待处理消息的数量。

下面是用于创建消息并将消息发送到ActiveMQ.Statistics.Broker的代码:

public void produceMessage(String queueName, String message, boolean replyToTempQueue) throws JMSException {

    // Create a connection factory.
    final ActiveMQConnectionFactory connectionFactory =
        new ActiveMQConnectionFactory(System.getenv("WIRE_LEVEL_ENDPOINT"));

    // Pass the username and password.
    connectionFactory.setUserName(System.getenv("ACTIVE_MQ_USERNAME"));
    connectionFactory.setPassword(System.getenv("ACTIVE_MQ_PASSWORD"));

    // Create a pooled connection factory.
    final PooledConnectionFactory pooledConnectionFactory = new PooledConnectionFactory();
    pooledConnectionFactory.setConnectionFactory(connectionFactory);
    pooledConnectionFactory.setMaxConnections(10);

    // Establish a connection for the producer.
    final Connection producerConnection = pooledConnectionFactory.createConnection();
    producerConnection.start();

    // Create a session.
    final Session producerSession = producerConnection.createSession(false, Session.AUTO_ACKNOWLEDGE);

    // Create a queue named "MyQueue".
    final ActiveMQQueue producerDestination = (ActiveMQQueue) producerSession.createQueue(queueName);

    // Create a producer from the session to the queue.
    final MessageProducer producer = producerSession.createProducer(producerDestination);
    producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);

    // Create a message.
    Message producerMessage = null;

    // Add a reply to queue if one has been provided.
    if (replyToTempQueue) {
      producerMessage = producerSession.createMapMessage();
      producerMessage.setJMSReplyTo(producerSession.createTemporaryQueue());
    } else {
      producerMessage = producerSession.createTextMessage(message);
    }

    // Send the message.
    producer.send(producerMessage);
    System.out.println("Message sent.");
    producer.close();
    producerSession.close();
    producerConnection.close();
  }

但是,它始终显示为0。这是为什么?

ActiveMQMapMessage {commandId = 6, responseRequired = false, messageId = ID:DESKTOP-CQNTDSL-64043-1583929718154-177:1:1:1:1, originalDestination = null, originalTransactionId = null, producerId = ID:DESKTOP-CQNTDSL-64043-1583929718154-177:1:1:1, destination = queue://ActiveMQ.Statistics.Broker, transactionId = null, expiration = 0, timestamp = 1583946785436, arrival = 0, brokerInTime = 1583946785552, brokerOutTime = 1583946785811, correlationId = null, replyTo = temp-queue://ID:DESKTOP-CQNTDSL-64043-1583929718154-177:1:1, persistent = false, type = null, priority = 4, groupID = null, groupSequence = 0, targetConsumerId = null, compressed = false, userID = null, content = null, marshalledProperties = null, dataStructure = null, redeliveryCounter = 0, size = 0, properties = null, readOnlyProperties = true, readOnlyBody = true, droppable = false, jmsXGroupFirstForConsumer = false} ActiveMQMapMessage{ theTable = {} }

1 个答案:

答案 0 :(得分:0)

您正在查看的size并不表示代理中待处理消息的数量。您需要检查enqueueCount而不是size的值。根据{{​​3}},在查询ActiveMQ.Statistics.Broker时将返回此值。

您还可以通过查询ActiveMQ.Statistics.Destination来获取特定目的地的数据。来自documentation

...要查询目的地的统计信息,只需向以ActiveMQ.Statistics.Destination开头的目的地名称发送一条消息即可。例如,要检索名称为TEST.FOO的队列的统计信息,请将空消息发送到名为ActiveMQ.Statistics.Destination.TEST.FOO的队列...

相关问题