1. JMS 入门小 Demo 1.1 点对点模式 点对点的模式主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向 ActiveMQ 发送消息,发送的消息,将会先进入队列中,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在 activemq 服务器, 直到接收端接收消息,点对点的消息模式可以有多个发送端,多个接收端,但是一条消息, 只会被一个接收端给接收到,哪个接收端先连上 ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息。 1.1.1 消息生产者 (1)创建工程 jmsDemo ,引入依赖
<dependency>
 
<groupId>org.apache.activemq</groupId>
 
<artifactId>activemq-client</artifactId>
 
<version>5.13.4</version>
 
</dependency>

(2)创建类 QueueProducer main 方法代码如下:

//1.创建连接工厂
 
ConnectionFactory  connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
 
Connection  connection  =  connectionFactory.createConnection();
 
//3.启动连接connection.start();
//4.获取 session    (参数 1:是否启动事务,参数 2:消息确认模式)
 
Session  session  =  connection.createSession(false,  Session.AUTO_ACKNOWLEDGE);
 
 
//5.创建队列对象
 
Queue  queue  =  session.createQueue("test-queue");
 
//6.创建消息生产者
 
MessageProducer  producer  =  session.createProducer(queue);
 
//7.创建消息
 
TextMessage  textMessage  =  session.createTextMessage("欢迎来到神奇的品优购世界");
 
//8.发送消息producer.send(textMessage);
//9.关闭资源
 
producer.close(); session.close();
connection.close();

上述代码中第 4 步创建 session 的两个参数: 第 1 个参数 是否使用事务第 2 个参数 消息的确认模式 · AUTO_ACKNOWLEDGE = 1 自动确认 · CLIENT_ACKNOWLEDGE = 2 客户端手动确认 · DUPS_OK_ACKNOWLEDGE = 3 自动批量确认 · SESSION_TRANSACTED = 0 事务提交并确认运行后通过 ActiveMQ 管理界面查询 1.1.1 消息消费者 创建类 QueueConsumer ,main 方法代码如下:

//1.创建连接工厂
 
ConnectionFactory  connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
 
Connection  connection  =  connectionFactory.createConnection();
 
//3.启动连接connection.start();
//4.获取 session    (参数 1:是否启动事务,参数 2:消息确认模式)
 
Session  session  =  connection.createSession(false,  Session.AUTO_ACKNOWLEDGE);
 
//5.创建队列对象
 
Queue  queue  =  session.createQueue("test-queue");
 
//6.创建消息消费
 
MessageConsumer  consumer  =  session.createConsumer(queue);
//7.监听消息
 
consumer.setMessageListener(new  MessageListener()  {
 
public  void  onMessage(Message  message)  { TextMessage  textMessage=(TextMessage)message; try {
System.out.println("接收到消息:"+textMessage.getText());
 
}  catch  (JMSException  e)  {
 
//  TODO  Auto-generated  catch  block e.printStackTrace();
}
 
}
 
});
 
//8.等待键盘输入System.in.read();
//9.关闭资源
 
consumer.close(); session.close();
connection.close();

执行后看到控制台输出 1.1.1 运行测试 同时开启 2 个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现只有一个消费者会接收到消息。 2.2 发布/订阅模式 2.2.1 消息生产者 创建类 TopicProducer ,main 方法代码如下:

//1.创建连接工厂
 
ConnectionFactory  connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
 
Connection  connection  =  connectionFactory.createConnection();
 
//3.启动连接connection.start();
//4.获取 session    (参数 1:是否启动事务,参数 2:消息确认模式)
 
Session  session  =  connection.createSession(false,  Session.AUTO_ACKNOWLEDGE);
 
//5.创建主题对象
 
Topic  topic  =  session.createTopic("test-topic");
 
//6.创建消息生产者
 
MessageProducer  producer  =  session.createProducer(topic);
 
//7.创建消息
 
TextMessage  textMessage  =  session.createTextMessage("欢迎来到神奇的品优购世界");
 
//8.发送消息producer.send(textMessage);

//9.关闭资源

producer.close(); session.close(); connection.close(); 运行效果如下: 2.2.1 消息消费者 创建类 TopicConsumer ,main 方法代码如下:

//1.创建连接工厂
 
ConnectionFactory  connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
 
Connection  connection  =  connectionFactory.createConnection();
 
//3.启动连接connection.start();
//4.获取 session    (参数 1:是否启动事务,参数 2:消息确认模式)
 
Session  session  =  connection.createSession(false,  Session.AUTO_ACKNOWLEDGE);
 
//5.创建主题对象
 
//Queue  queue  =  session.createQueue("test-queue"); Topic  topic  =  session.createTopic("test-topic");
//6.创建消息消费
 
MessageConsumer  consumer  =  session.createConsumer(topic);
//7.监听消息
 
consumer.setMessageListener(new  MessageListener()  {
 
public  void  onMessage(Message  message)  { TextMessage  textMessage=(TextMessage)message; try {
System.out.println("接收到消息:"+textMessage.getText());
 
}  catch  (JMSException  e)  {
 
//  TODO  Auto-generated  catch  block e.printStackTrace();
}
 
}
 
});
 
//8.等待键盘输入System.in.read();
//9.关闭资源
consumer.close(); session.close(); connection.close();
2.2.1 运行测试

同时开启 2 个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现每个消费者会接收到消息。