队列消息(无须先预定)
1、创建一个maven项目
2、导入ActiveMQ所需要的jar包,添加pom文件如下:
<!--引用ActiveMQ相关包-->
<dependencies>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.12.0</version>
</dependency>
</dependencies>
3、创建一个生产者:
package com.jms.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
public class AppProducer {
private static final String url="tcp://localhost:61616";
//创建队列的名字
private static final String queueName="queue-test";
public static void main(String [] args)throws JMSException{
//1.创建连接工厂ConnectionFactory
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);
//2.创建连接Connection
Connection connection=connectionFactory.createConnection();
//3.启动连接
connection.start();
//4.创建会话 第一个参数是:是否在事物中处理
Session session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建一个目标
Destination destination=session.createQueue(queueName);
//6.创建生产者
MessageProducer producer=session.createProducer(destination);
for (int i=0;i<=100;i++){
//7.创建消息
TextMessage textMessage=session.createTextMessage("test"+i);
//8.发布消息
producer.send(textMessage);
System.out.println("发送消息"+textMessage.getText());
}
//9.关闭连接
connection.close();
}
}
4、启动项目
5、创建一个消费者
package com.jms.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
public class AppConsumer {
private static final String url = "tcp://localhost:61616";
//创建队列的名字
private static final String queueName = "queue-test";
public static void main(String[] args) throws JMSException {
//1.创建连接工厂ConnectionFactory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
//2.创建连接Connection
Connection connection = connectionFactory.createConnection();
//3.启动连接
connection.start();
//4.创建会话 第一个参数是:是否在事物中处理
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建一个目标
Destination destination = session.createQueue(queueName);
//6.创建一个消费者
MessageConsumer consumer = session.createConsumer(destination);
//7.创建一个监听器
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
TextMessage textMessage = (TextMessage) message;
try {
System.out.println("接收消息" + textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
});
//8.关闭连接
//connection.close();
}
}
6、启动项目
7、再次启动消费者类,启动生产者类:
生产者信息,被消费者平分