您好,我正在编写某种简单的测试场景,在其中执行以下源代码:
这是我的 send() 方法:
public void send() throws JMSException {
Session session = null;
MessageProducer producer = null;
try {
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Destination destination = session.createQueue("TEST.FOO");
producer = session.createProducer(destination);
producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
byte[] uselessData = new byte[1024];
BytesMessage message = session.createBytesMessage();
message.writeBytes(uselessData);
producer.send(message);
} finally {
producer.close();
session.close();
}
}
这是我的接收()方法:
public void receive() throws JMSException {
Session session = null;
MessageConsumer consumer = null;
try {
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Destination destination = session.createQueue("TEST.FOO");
consumer = session.createConsumer(destination);
Message hugeMessage = consumer.receiveNoWait();
if (hugeMessage == null) {
System.out.println("Message was not received");
unsucsesfullCount++;
} else {
if (hugeMessage instanceof BytesMessage) {
System.out.println("Message received");
}
}
} finally {
consumer.close();
session.close();
}
}
我执行:
send();
receive();
receiveNoWait()之后的消息值始终为null。
我的问题是当代理中有消息时,receiveNoWait()是否保证消息传递?send()已成功执行,因此目标中至少有一条消息。
我已经在规范中进行了搜索,但是如果在代理端可用的消息应该由客户端的receiveNoWait()显式接收,并没有真正明确的定义。
另外我想问一下,如果receiveNoWait()没有可用的消息,是否应该触发broker 中的一些刷新消费者进程,所以下一个receiveNoWait()会收到消息?
我提供的示例代码在 ActiveMQ 上运行,但我的问题比提供程序更具体,因为我对其他 JMS 提供程序有相同的观察。