首页 > 编程语言 > 详细

Spring Boot 整合 JMS(Active MQ 实现)

时间:2020-06-14 22:48:13      阅读:64      评论:0      收藏:0      [点我收藏+]
      我们使用jms一般是使用spring-jms和activemq相结合,通过spring的JmsTemplate发送消息到指定的Destination。本文以点到点模式为例,演示如何在Spring Boot中整合 JMS 和 Active MQ ,实现 MQ 消息的生产与消费。
 

1 安装ActiveMQ

      关于具体的安装步骤,请参考专门介绍安装与部署的另一篇博文《ActiveMQ的安装与部署》。

2 配置Active MQ 依赖

      关于如何搭建 Spring Boot工程,请移步《基于 intellij IDEA 快速搭建Spring Boot项目》。假设项目已经创建完毕,在项目 pom 文件中加入Active MQ依赖:
 
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-activemq</artifactId>
    <version>2.2.7.RELEASE</version>
</dependency>

 3 修改application.properties配置文件

      在application.properties中配置Active MQ:

spring.activemq.broker-url=tcp://localhost:61616
spring.activemq.in-memory=true
spring.activemq.pool.enabled=false
#默认值false,表示点到点模式,true时代表发布订阅模式
spring.jms.pub-sub-domain=false

 4 创建消息生产者和消费者

      本文以点到点模式演示。新增消息生产者:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsMessagingTemplate;
import org.springframework.stereotype.Service;

import javax.jms.Destination;

@Service("producer")
public class Producer {
    /**
     * 也可以注入JmsTemplate,JmsMessagingTemplate对JmsTemplate进行了封装
     */
    @Autowired
    private JmsMessagingTemplate jmsTemplate;

    /**
     * 发送消息,destination是发送到的队列,message是待发送的消息
     *
     * @param destination
     * @param message
     */
    public void sendMessage(Destination destination, final String message) {
        jmsTemplate.convertAndSend(destination, message);
    }
}

       新增消息消费者:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.stereotype.Component;

@Component
public class ConsumerListener {
    private static Logger logger = LoggerFactory.getLogger(Consumer.class);
    /**
     * 使用JmsListener配置消费者监听的队列
     * @param receivedMsg 接收到的消息
     */
    @JmsListener(destination = "myDest.queue")
    public void receiveQueue(String receivedMsg) {
        logger.info("Consumer收到的报文为: {}", receivedMsg);
    }
}

       消费者2 ConsumerListener2 的代码同上,但是日志如下: 

        logger.info("Consumer2收到的报文为: {}", receivedMsg);

 温馨提示,消息消费者和生产者的类上必须加上注解 @Component 或者 @Service,使得消息消费者类就会被委派给Listener类,原理类似于使用SessionAwareMessageListener以及MessageListenerAdapter来实现消息驱动POJO。

5 测试 MQ

      在Junit测试类中新增测试方法
import org.apache.activemq.command.ActiveMQQueue;
import javax.jms.Destination;

@Autowired
private Producer producer;
@Test
public void jmsActiveMqTest() throws InterruptedException {
    Destination destination = new ActiveMQQueue("myDest.queue");
    for (int i = 0; i < 21; i++) {
        producer.sendMessage(destination, String.format("My name is Wiener%s", i));
    }
}

       测试结果:

Consumer收到的报文为: My name is Wiener0
Consumer2 收到的报文为:My name is Wiener1
Consumer收到的报文为: My name is Wiener2
Consumer2 收到的报文为:My name is Wiener3
Consumer收到的报文为: My name is Wiener4
Consumer2 收到的报文为:My name is Wiener5
Consumer收到的报文为: My name is Wiener6
Consumer2 收到的报文为:My name is Wiener7
...
      经过上面的五个步骤,spring Boot、Jms 和 Active MQ 就基本上整合完成了,是不是使用起来很方便了!
 

Reference

 
 
 

Spring Boot 整合 JMS(Active MQ 实现)

原文:https://www.cnblogs.com/east7/p/13127364.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!