开始实战之前,我们先来看一下JMS的基础 知识:
消息中间件初识
然后进入敲代码阶段:
队列模式:
首先我们来创建一个队列模式的ActiveMq。
AppProducer的代码如下:
package com.martina.jms.test1;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
public class AppProducer {
private static final String url="tcp://127.0.0.1:61616";
private static final String queueName="queue-test";
public static void main(String[] args) throws JMSException {
//创建ConnectionFactory
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);
//创建Connection
Connection connection=connectionFactory.createConnection();
//启动连接
connection.start();
//创建会话
/* 在connection创建session的时候,第一个参数决定session事物是否开启,true时session事物开启。为false时 ,session事物关闭。
Session.AUTO-ACKNOWLEDGE,session负责发送过去消息,收到自动确认。
Session.CLIENT-ACKNOWLEDGE(接收端确认接收到这条消息,调用这条消息的确认方法)。
session.DUPS_OK_ACKNOWLEDGE(懒散的确认方法,这种确认方法有可能传递的一些复制信息会出错)。
*/
Session session=connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
//创建一个目标
Destination destination=session.createQueue(queueName);
//创建一个生产者,然后创建并发送消息
MessageProducer producer=session.createProducer(destination);
for(int i=0;i<20;i++){
TextMessage textMessage=session.createTextMessage("test");
// TextMessage textMessage=session.createTextMessage("test"+i);
producer.send(textMessage);
System.out.println("发送消息"+textMessage.getText());
}
//最后关闭连接
connection.close();
}
}
然后执行AppProducer之后,可以看到
然后我们创建一个AppConsumer类,代码如下:
package com.martina.jms.testQueue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
public class AppConsumer {
private static final String url="tcp://127.0.0.1:61616";
private static final String queueName="queue-test";
public static void main(String[] args) throws JMSException {
//创建ConnectionFactory
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);
//创建Connection
Connection connection=connectionFactory.createConnection();
//启动连接
connection.start();
//创建会话
/* 在connection创建session的时候,第一个参数决定session事物是否开启,true时session事物开启。为false时 ,session事物关闭。
Session.AUTO-ACKNOWLEDGE,session负责发送过去消息,收到自动确认。
Session.CLIENT-ACKNOWLEDGE(接收端确认接收到这条消息,调用这条消息的确认方法)。
session.DUPS_OK_ACKNOWLEDGE(懒散的确认方法,这种确认方法有可能传递的一些复制信息会出错)。
*/
Session session=connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
//创建一个目标
Destination destination=session.createQueue(queueName);
//创建一个消费者
final MessageConsumer consumer=session.createConsumer(destination);
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
TextMessage textMessage=(TextMessage) message;
try{
System.out.println("接收消息"+textMessage.getText());
}catch (JMSException e){
e.printStackTrace();
}
}
});
//最后关闭连接
//注意这里:当开始时候就直接关闭的话,上面的消息就不会输出,所以要注释掉这一行
// connection.close();
}
}
然后我们执行一个Consumer,就会接收到我们之前Producer发送的20条消息,再执行新的Consumer时,就不会有接收到任何消息。
然后我们清空所有之后,先执行起两个Consumer,然后执行一个Producer,就会发现两个Consumer的控制台输出情况如下:也就是两个consumer均分所有的Producer产生的消息。
主题模式:
主题模式的创建和队列模式的创建相差无几:主要是修改以下内容:
运行AppProducer程序之后,我们直接查看ActiveMq的官网:找到对应的Topics:
就会找到我们自己创建的Topics,以及发送的消息数量。
这时候运行Topic下的APPConsumer,就会发现没有接收到任何消息。因为在 主题模式下,只有消费者提前订阅了主题,才可以接收到消息发送者的消息。
那么我们可以重新执行AppProducer(保持AppConsumer开启),那么就会发现consumer中接收到了消息。
好的,接下来我们来证明主题模式下,两个应用(消费者)都会收到所有的producer发送的消息。
开启两个消费者,clear All 控制台,重新执行Producer,查看两个Consumer控制台,就会发现两个Consumer接收消息情况如下:
也就是证明了两个不同方式的(队列和主题模式)区别:队列是平均分Producer发送的消息,主题是接收所有的消息。