spring boot整合JMS(ActiveMQ实现)

一、安装ActiveMQ

具体的安装步骤,请参考我的另一篇博文:

http://blog.csdn.net/liuchuanhong1/article/details/52057711

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

三、工程结构

pom依赖如下:

[html] view plain copy

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.chhliu.springboot.jms</groupId>
  6. <artifactId>springboot-jms</artifactId>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <packaging>jar</packaging>
  9. <name>springboot-jms</name>
  10. <description>Demo project for Spring Boot Jms</description>
  11. <parent>
  12. <groupId>org.springframework.boot</groupId>
  13. <artifactId>spring-boot-starter-parent</artifactId>
  14. <version>1.4.3.RELEASE</version>
  15. <relativePath/> <!-- lookup parent from repository -->
  16. </parent>
  17. <properties>
  18. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  19. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  20. <java.version>1.7</java.version>
  21. </properties>
  22. <dependencies>
  23. <dependency>
  24. <groupId>org.springframework.boot</groupId>
  25. <artifactId>spring-boot-starter-activemq</artifactId>
  26. </dependency>
  27. <dependency>
  28. <groupId>org.springframework.boot</groupId>
  29. <artifactId>spring-boot-starter-test</artifactId>
  30. <scope>test</scope>
  31. </dependency>
  32. </dependencies>
  33. <build>
  34. <plugins>
  35. <plugin>
  36. <groupId>org.springframework.boot</groupId>
  37. <artifactId>spring-boot-maven-plugin</artifactId>
  38. </plugin>
  39. </plugins>
  40. </build>
  41. </project>

四、修改application.properties配置文件

[java] view plain copy

  1. ## URL of the ActiveMQ broker. Auto-generated by default. For instance `tcp://localhost:61616`
  2. # failover:(tcp://localhost:61616,tcp://localhost:61617)
  3. # tcp://localhost:61616
  4. spring.activemq.broker-url=tcp://localhost:61616
  5. spring.activemq.in-memory=true
  6. spring.activemq.pool.enabled=false

五、消息生产者

[java] view plain copy

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

六、消息消费者

[java] view plain copy

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

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

七、测试

[java] view plain copy

  1. package com.chhliu.springboot.jms;
  2. import javax.jms.Destination;
  3. import org.apache.activemq.command.ActiveMQQueue;
  4. import org.junit.Test;
  5. import org.junit.runner.RunWith;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.boot.test.context.SpringBootTest;
  8. import org.springframework.test.context.junit4.SpringRunner;
  9. @RunWith(SpringRunner.class)
  10. @SpringBootTest
  11. public class SpringbootJmsApplicationTests {
  12. @Autowired
  13. private Producer producer;
  14. @Test
  15. public void contextLoads() throws InterruptedException {
  16. Destination destination = new ActiveMQQueue("mytest.queue");
  17. for(int i=0; i<100; i++){
  18. producer.sendMessage(destination, "myname is chhliu!!!");
  19. }
  20. }
  21. }

测试结果如下:

[java] view plain copy

  1. Consumer2收到的报文为:myname is chhliu!!!
  2. Consumer收到的报文为:myname is chhliu!!!
  3. Consumer2收到的报文为:myname is chhliu!!!
  4. Consumer收到的报文为:myname is chhliu!!!
  5. Consumer2收到的报文为:myname is chhliu!!!
  6. Consumer收到的报文为:myname is chhliu!!!
  7. Consumer2收到的报文为:myname is chhliu!!!
  8. Consumer收到的报文为:myname is chhliu!!!
  9. Consumer2收到的报文为:myname is chhliu!!!
  10. Consumer收到的报文为:myname is chhliu!!!
  11. Consumer2收到的报文为:myname is chhliu!!!
  12. Consumer收到的报文为:myname is chhliu!!!
  13. Consumer2收到的报文为:myname is chhliu!!!

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

八、实现双向队列

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

[java] view plain copy

  1. package com.chhliu.springboot.jms;
  2. import org.springframework.jms.annotation.JmsListener;
  3. import org.springframework.messaging.handler.annotation.SendTo;
  4. import org.springframework.stereotype.Component;
  5. @Component
  6. public class Consumer2 {
  7. @JmsListener(destination = "mytest.queue")
  8. @SendTo("out.queue")
  9. public String receiveQueue(String text) {
  10. System.out.println("Consumer2收到的报文为:"+text);
  11. return "return message"+text;
  12. }
  13. }

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

进入Browse界面观看:

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

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

九、对Producer进行改造

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

[java] view plain copy

  1. package com.chhliu.springboot.jms;
  2. import javax.jms.Destination;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.jms.annotation.JmsListener;
  5. import org.springframework.jms.core.JmsMessagingTemplate;
  6. import org.springframework.stereotype.Service;
  7. @Service("producer")
  8. public class Producer {
  9. @Autowired
  10. private JmsMessagingTemplate jmsTemplate;
  11. public void sendMessage(Destination destination, final String message){
  12. jmsTemplate.convertAndSend(destination, message);
  13. }
  14. @JmsListener(destination="out.queue")
  15. public void consumerMessage(String text){
  16. System.out.println("从out.queue队列收到的回复报文为:"+text);
  17. }
  18. }

测试结果如下:

[java] view plain copy

  1. 从out.queue队列收到的回复报文为:return messagemyname is chhliu!!!
  2. Consumer收到的报文为:myname is chhliu!!!
  3. Consumer2收到的报文为:myname is chhliu!!!
  4. 从out.queue队列收到的回复报文为:return messagemyname is chhliu!!!
  5. Consumer收到的报文为:myname is chhliu!!!
  6. Consumer2收到的报文为:myname is chhliu!!!
  7. 从out.queue队列收到的回复报文为:return messagemyname is chhliu!!!
  8. Consumer收到的报文为:myname is chhliu!!!
  9. Consumer2收到的报文为:myname is chhliu!!!
  10. 从out.queue队列收到的回复报文为:return messagemyname is chhliu!!!
3
时间: 2024-08-06 07:34:51

spring boot整合JMS(ActiveMQ实现)的相关文章

activeMQ入门+spring boot整合activeMQ

最近想要学习MOM(消息中间件:Message Oriented Middleware),就从比较基础的activeMQ学起,rabbitMQ.zeroMQ.rocketMQ.Kafka等后续再去学习. 上面说activeMQ是一种消息中间件,可是为什么要使用activeMQ? 在没有使用JMS的时候,很多应用会出现同步通信(客户端发起请求后需要等待服务端返回结果才能继续执行).客户端服务端耦合.单一点对点(P2P)通信的问题,JMS可以通过面向消息中间件的方式很好的解决了上面的问题. JMS规

spring boot整合activeMQ

spring boot整合activeMQ spring boot整合MQ以后,对于消息的发送和接收操作更加便捷.本文将通过四个案例,分别讲解spring boot整合MQ: spring boot整合MQ发送queue消息 spring boot整合MQ发送topic消息 spring boot整合MQ以后如何让queue和topic消息共存 spring boot整合MQ以后topic消息如何持久化 下面分别进行讲解: 一. spring boot 整合MQ发送queue消息 搭建测试工程,

Spring Boot (十三): Spring Boot 整合 RabbitMQ

1. 前言 RabbitMQ 是一个消息队列,说到消息队列,大家可能多多少少有听过,它主要的功能是用来实现应用服务的异步与解耦,同时也能起到削峰填谷.消息分发的作用. 消息队列在比较主要的一个作用是用来做应用服务的解耦,消息从消息的生产者传递到消息队列,消费者从消息队列中获取消息并进行消费,生产者不需要管是谁在消费消息,消费者也无需关注消息是由谁来生产的.在分布式的系统中,消息队列也会被用在其他地方,比如分布式事务的支持,代表如阿里开源的 RocketMQ . 当然,我们本篇文章的主角还是 Ra

spring boot 整合 quartz 集群环境 实现 动态定时任务配置【原】

最近做了一个spring boot 整合 quartz  实现 动态定时任务配置,在集群环境下运行的 任务.能够对定时任务,动态的进行增删改查,界面效果图如下: 1. 在项目中引入jar 2. 将需要的表导入数据库 官网上有不同数据库的脚本,找到对应的,导入即可 3. java 代码 将quartz 的相关配置文件,配置为暴露bean,方便后期引用. 有一处关键的地方,就是注入spring 上下文,也可以算是一个坑.如果,不注入spring 上下文,那么新添加的定时任务job,是新new 的一个

spring boot 整合spring Data JPA+Spring Security+Thymeleaf框架(上)

最近上班太忙所以耽搁了给大家分享实战springboot 框架的使用. 下面是spring boot 整合多个框架的使用. 首先是准备工作要做好. 第一  导入框架所需的包,我们用的事maven 进行对包的管理. 以上的举例是本人的H5DS的真实的后台管理项目,这个项目正在盛情融资中,各位多多捧点人场.关注一下软件发展的动态,说不定以后就是您的生活不可或缺的软件哟. 点击打开链接.闲话少说.现在切入正题. 第二,写点配置文件 第三,spring data -设计一个简单的po关系,这里需要下载一

spring boot整合jsp的那些坑(spring boot 学习笔记之三)

Spring Boot 整合 Jsp 步骤: 1.新建一个spring boot项目 2.修改pom文件 <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <depend

Spring boot整合jsp

这几天在集中学习Spring boot+Shiro框架,因为之前view层用jsp比较多,所以想在spring boot中配置jsp,但是spring boot官方不推荐使用jsp,因为jsp相对于一些模板引擎,性能都比较低,官方推荐使用thymeleaf,但是Spring boot整合jsp的过程已经完成,在这里记录一下. 这篇博文是在LZ上篇文章spring boot+mybatis整合基础上写的,开发工具仍然是Intellij idea.这篇文章的重点是Intellij idea的设置,否

企业分布式微服务云SpringCloud SpringBoot mybatis (十三)Spring Boot整合MyBatis

Spring中整合MyBatis就不多说了,最近大量使用Spring Boot,因此整理一下Spring Boot中整合MyBatis的步骤.搜了一下Spring Boot整合MyBatis的文章,方法都比较老,比较繁琐.查了一下文档,实际已经支持较为简单的整合与使用.下面就来详细介绍如何在Spring Boot中整合MyBatis,并通过注解方式实现映射. 整合MyBatis 新建Spring Boot项目,或以Chapter1为基础来操作 pom.xml中引入依赖 这里用到spring-bo

Spring Kafka和Spring Boot整合实现消息发送与消费简单案例

本文主要分享下Spring Boot和Spring Kafka如何配置整合,实现发送和接收来自Spring Kafka的消息. 先前我已经分享了Kafka的基本介绍与集群环境搭建方法.关于Kafka的介绍请阅读Apache Kafka简介与安装(一),关于Kafka安装请阅读Apache Kafka安装,关于Kafka集群环境搭建请阅读Apache Kafka集群环境搭建 .这里关于服务器环境搭建不在赘述. Spring Kafka整合Spring Boot创建生产者客户端案例 创建一个kafk