2.3 KiB
2.3 KiB
| title | date | categories | tags | ||
|---|---|---|---|---|---|
| 消息中间件(2)-java连接ActiveMQ | 2018-11-2 15:59:34 |
|
|
使用java连接activeMQ
引入依赖
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.15.7</version>
</dependency>
1.连接ActiveMQ
//step1 创建连接工厂
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.142.128:61616");
//step2 创建连接
Connection connection = connectionFactory.createConnection();
//step3 启动连接
connection.start();
//step4 创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 第一个参数是是否使用事务, 第二个参数是应答模式, 这里是自动应答
//step5 创建一个目标(队列模式)
Queue queue = session.createQueue("queue-test");
// 主题模式
// Topic topic = session.createTopic("topic-test");
使用完毕之后需要调用close关闭连接
// 关闭连接
connection.close();
2.生产者
使用上面的步骤当中创建的会话, 使用生产者向消息中间件发送消息
// 创建生产者
MessageProducer producer = session.createProducer(queue);
// 创建消息
TextMessage textMessage = session.createTextMessage("这是一条测试消息");
// 发送消息
producer.send(textMessage);
3.消费者
创建连接和创建会话的步骤都是一样的
// 创建消费者
MessageConsumer consumer = session.createConsumer(destination);
// 创建监听器
consumer.setMessageListener(new MessageListener() {
@Override
public void onMessage(Message message) {
TextMessage textMessage = (TextMessage)message;
try {
System.out.println("接收消息:"+textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
});
注意:
- 由于监听操作是一个异步操作 创建并设置监听器之后, 不能立即关闭连接, 否则就无法接收到消息
- 这里如果写成lamdba表达式的形式会无法接收到消息, 暂时不明白为什么
在队列模式下, 如果有多个消费者, 每个消息只会被其中一个消费者接收 在主题模式下, 如果有多个消费者, 推送消息之后, 推送的消息会被在此之前建立监听的所有消费者接收 (基本类似于redis里面的发布订阅)