前言
假如:三个消费者同时关注并且订阅了一个公众号,公众号同时推送N份消息的时候,他们三个各收到的是N份,还是先到先得到全部,还是均分消息呢?
1、创建maven项目,导入pom.xml依赖包
<!--activemq所需依赖jar配置-->
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.15.9</version>
</dependency>
<!--lombok支持依赖包-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<scope>provided</scope>
</dependency>
2、JmsProduceTopic.java 生产者
/**
* 生产者(先订阅---微信公众号--只有订阅了----才能发布)
*/
public class JmsProduceTopic {
//工厂连接地址
private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";
//队列名称
private static final String TOPIC_NAME = "topic-wx";
public static void main(String[] args) throws JMSException {
//1、创建连接工厂,按照给定的url,采用默认的用户名和密码
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);
//2、通过连接工厂获得连接connection并启动访问
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//3、创建会话 两个参数:第一个(事务),第二个(签收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//4、创建目的地(队列还是主题),先创建主题
Topic topic = session.createTopic(TOPIC_NAME);
//5、创建消息的生产者
MessageProducer messageProducer = session.createProducer(topic);
//6、通过使用消息生产者生产3条消息发送到MQ主题里面
for (int i = 1; i <=3 ; i++) {
//7、创建消息
TextMessage textMessage = session.createTextMessage("topic---" + i);//理解为一个字符串
//8、通过消息生产者(MessageProducer)发送给MQ
messageProducer.send(textMessage);
}
//9、关闭资源
messageProducer.close();
session.close();
connection.close();
System.out.println("Topic主题消息发送完成!");
}
}
3、JmsConsumerMonitorTopic.java 消费者 异步非阻塞方式(监听方式)
/**
* 主题目的地:消费者 异步非阻塞方式(监听方式)
*/
public class JmsConsumerMonitorTopic {
//工厂连接地址
private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";
//队列名称
private static final String TOPIC_NAME = "topic-wx";
public static void main(String[] args) throws JMSException, IOException {
System.out.println("我是3号消费者......");
//1、创建连接工厂,按照给定的url,采用默认的用户名和密码
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);
//2、通过连接工厂获得连接connection并启动访问
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//3、创建会话 两个参数:第一个(事务),第二个(签收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//4、创建目的地(队列还是主题),先创建主题
Topic topic = session.createTopic(TOPIC_NAME);
//5、创建消费者
MessageConsumer messageConsumer = session.createConsumer(topic);
//6、通过监听的方式 lombok表达式
messageConsumer.setMessageListener(message -> {
if(null != message && message instanceof TextMessage) {
TextMessage textMessage = (TextMessage) message;
try {
System.out.println("消费者接受到Topic消息:" + textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
});
System.in.read(); //保证控制台不灭,一直输出
messageConsumer.close();
session.close();
connection.close();
}
}
4、三个消费者监听着同一个主题
即三个消费者同时关注并且订阅了一个公众号,公众号同时推送N份消息的时候,他们三个各收到的消息也是N份。
生产者发送消息,消费者订阅之后,接受到消息:
控制台打印: