在创建队列时,需要设置队列配置参数"max-consumers"和"consumer-window-size",然后使用不同的消息处理器(MessageHandler)来处理每个消息。以下是示例代码:
Map queueConfig = new HashMap<>();
queueConfig.put("max-consumers", 1);
queueConfig.put("consumer-window-size", 0);
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
ActiveMQQueue queue = new ActiveMQQueue("example.queue");
try (ActiveMQConnection connection = (ActiveMQConnection) connectionFactory.createConnection()) {
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Queue queue = session.createQueue("example.queue");
session.createConsumer(queue, new CustomMessageHandler());
connection.start();
} catch (JMSException e) {
e.printStackTrace();
}
public class CustomMessageHandler implements MessageHandler {
@Override
public void onMessage(Message message) {
// 处理接收到的消息
}
}
使用"max-consumers"和"consumer-window-size"限制了只能有一个消费者连接到队列,并且设置了窗口大小为0,表示每个消费者只处理一个消息。通过使用自定义的消息处理器来处理每个消息,可以保证消息的顺序性。