在Java中启动监听MQ消息的代码可以使用JMS(Java Message Service)的API来实现。下面是一个简单的示例代码:
import javax.jms.*;
import org.apache.activemq.ActiveMQConnectionFactory;
public class MQMessageListener {
public static void main(String[] args) {
try {
// 创建连接工厂
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
// 创建连接
Connection connection = connectionFactory.createConnection();
connection.start();
// 创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建目的地(队列或主题)
Destination destination = session.createQueue("myQueue");
// 创建消息消费者
MessageConsumer consumer = session.createConsumer(destination);
// 设置消息监听器
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
try {
// 处理收到的消息
if (message instanceof TextMessage) {
TextMessage textMessage = (TextMessage) message;
System.out.println("Received message: " + textMessage.getText());
}
} catch (JMSException e) {
e.printStackTrace();
}
}
});
// 等待消息的到达
Thread.sleep(10000);
// 关闭连接
consumer.close();
session.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
在上述代码中,首先创建了一个连接工厂(ActiveMQConnectionFactory),然后使用连接工厂创建了连接(Connection),再使用连接创建了会话(Session),会话用于发送和接收消息。接着创建了一个消息消费者(MessageConsumer),并通过调用setMessageListener
方法设置了一个消息监听器。消息监听器的onMessage
方法会在有消息到达时被调用,可以在该方法中对收到的消息进行处理。最后通过调用Thread.sleep
方法等待消息的到达,关闭连接时需要分别关闭消息消费者、会话和连接。