spring boot整合JMS的示例分析

发布时间:2021-07-08 13:49:20 作者:小新
来源:亿速云 阅读:277

这篇文章将为大家详细讲解有关spring boot整合JMS的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、安装ActiveMQ

具体的安装步骤,请参考我的另一篇文章:https://www.jb51.net/article/127117.htm

二、新建spring boot工程,并加入JMS(ActiveMQ)依赖

spring boot整合JMS的示例分析

三、工程结构

spring boot整合JMS的示例分析

pom依赖如下:

<?xml version="1.0" encoding="UTF-8"?> 
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
  <modelVersion>4.0.0</modelVersion> 
 
  <groupId>com.chhliu.springboot.jms</groupId> 
  <artifactId>springboot-jms</artifactId> 
  <version>0.0.1-SNAPSHOT</version> 
  <packaging>jar</packaging> 
 
  <name>springboot-jms</name> 
  <description>Demo project for Spring Boot Jms</description> 
 
  <parent> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-parent</artifactId> 
    <version>1.4.3.RELEASE</version> 
    <relativePath/> <!-- lookup parent from repository --> 
  </parent> 
 
  <properties> 
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> 
    <java.version>1.7</java.version> 
  </properties> 
 
  <dependencies> 
    <dependency> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-starter-activemq</artifactId> 
    </dependency> 
 
    <dependency> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-starter-test</artifactId> 
      <scope>test</scope> 
    </dependency> 
  </dependencies> 
 
  <build> 
    <plugins> 
      <plugin> 
        <groupId>org.springframework.boot</groupId> 
        <artifactId>spring-boot-maven-plugin</artifactId> 
      </plugin> 
    </plugins> 
  </build> 
</project>

四、修改application.properties配置文件

## URL of the ActiveMQ broker. Auto-generated by default. For instance `tcp://localhost:61616` 
# failover:(tcp://localhost:61616,tcp://localhost:61617) 
# tcp://localhost:61616 
spring.activemq.broker-url=tcp://localhost:61616 
spring.activemq.in-memory=true 
spring.activemq.pool.enabled=false //如果此处设置为true,需要加如下的依赖包,否则会自动配置失败,报JmsMessagingTemplate注入失败
<dependency> 
      <groupId>org.apache.activemq</groupId> 
      <artifactId>activemq-pool</artifactId> 
      <!-- <version>5.7.0</version> --> 
    </dependency>

五、消息生产者

package com.chhliu.springboot.jms; 
 
import javax.jms.Destination; 
 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.jms.core.JmsMessagingTemplate; 
import org.springframework.stereotype.Service; 
 
@Service("producer") 
public class Producer { 
  @Autowired // 也可以注入JmsTemplate,JmsMessagingTemplate对JmsTemplate进行了封装 
  private JmsMessagingTemplate jmsTemplate; 
  // 发送消息,destination是发送到的队列,message是待发送的消息 
  public void sendMessage(Destination destination, final String message){ 
    jmsTemplate.convertAndSend(destination, message); 
  } 
}

六、消息消费者

package com.chhliu.springboot.jms; 
 
import org.springframework.jms.annotation.JmsListener; 
import org.springframework.stereotype.Component; 
 
@Component 
public class Consumer { 
    // 使用JmsListener配置消费者监听的队列,其中text是接收到的消息 
  @JmsListener(destination = "mytest.queue") 
  public void receiveQueue(String text) { 
    System.out.println("Consumer收到的报文为:"+text); 
  } 
}

消费者2的代码同上,注意,消息消费者的类上必须加上@Component,或者是@Service,这样的话,消息消费者类就会被委派给Listener类,原理类似于使用SessionAwareMessageListener以及MessageListenerAdapter来实现消息驱动POJO

七、测试

package com.chhliu.springboot.jms; 
 
import javax.jms.Destination; 
 
import org.apache.activemq.command.ActiveMQQueue; 
import org.junit.Test; 
import org.junit.runner.RunWith; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.boot.test.context.SpringBootTest; 
import org.springframework.test.context.junit4.SpringRunner; 
 
@RunWith(SpringRunner.class) 
@SpringBootTest 
public class SpringbootJmsApplicationTests { 
   
  @Autowired 
  private Producer producer; 
   
  @Test 
  public void contextLoads() throws InterruptedException { 
    Destination destination = new ActiveMQQueue("mytest.queue"); 
     
    for(int i=0; i<100; i++){ 
      producer.sendMessage(destination, "myname is chhliu!!!"); 
    } 
  } 
 
}

测试结果如下:

Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!!

经过上面的几个步骤,spring boot和Jms就基本上整合完成了,是不是使用起来很方便了!

八、实现双向队列

1、下面首先来对Consumer2这个消费者来进行下改造,代码如下:

package com.chhliu.springboot.jms; 
 
import org.springframework.jms.annotation.JmsListener; 
import org.springframework.messaging.handler.annotation.SendTo; 
import org.springframework.stereotype.Component; 
 
@Component 
public class Consumer2 { 
 
  @JmsListener(destination = "mytest.queue") 
  @SendTo("out.queue") 
  public String receiveQueue(String text) { 
    System.out.println("Consumer2收到的报文为:"+text); 
    return "return message"+text; 
  } 
}

从上面的代码可以看出,我们在receiveQueue方法上面多加了一个注解@SendTo("out.queue"),该注解的意思是将return回的值,再发送的"out.queue"队列中,下面我们再来跑一下前面的测试,在监控页面中,我们发现,"out.queue"队列中已经有内容了,如下:

spring boot整合JMS的示例分析

进入Browse界面观看:

spring boot整合JMS的示例分析

最后看下收到的具体信息:

spring boot整合JMS的示例分析

我们发现,该队列中的消息,就是我们返回的值!

九、对Producer进行改造

通过上面的示例,我们现在对Producer进行改造,使其既能生产报文,又能消费队列中的报文,代码如下:

package com.chhliu.springboot.jms; 
 
import javax.jms.Destination; 
 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.jms.annotation.JmsListener; 
import org.springframework.jms.core.JmsMessagingTemplate; 
import org.springframework.stereotype.Service; 
 
@Service("producer") 
public class Producer { 
  @Autowired 
  private JmsMessagingTemplate jmsTemplate; 
   
  public void sendMessage(Destination destination, final String message){ 
    jmsTemplate.convertAndSend(destination, message); 
  } 
   
  @JmsListener(destination="out.queue") 
  public void consumerMessage(String text){ 
    System.out.println("从out.queue队列收到的回复报文为:"+text); 
  } 
}

测试结果如下:

从out.queue队列收到的回复报文为:return messagemyname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
从out.queue队列收到的回复报文为:return messagemyname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
从out.queue队列收到的回复报文为:return messagemyname is chhliu!!! 
Consumer收到的报文为:myname is chhliu!!! 
Consumer2收到的报文为:myname is chhliu!!! 
从out.queue队列收到的回复报文为:return messagemyname is chhliu!!!

关于“spring boot整合JMS的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

推荐阅读:
  1. Spring Boot 整合 rabbitmq
  2. Spring Boot及idea整合jsp的示例分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

spring boot jms

上一篇:SpringBoot+Redis如何执行lua脚本

下一篇:spring-boot如何读取props和yml配置文件

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》