浅谈Spring Boot 整合ActiveMQ的过程

作者:虾游于海 时间:2022-03-22 05:20:27 

RabbitMQ是比较常用的AMQP实现,这篇文章是一个简单的Spring boot整合RabbitMQ的教程。

安装ActiveMQ服务器,(也可以不安装,如果不安装,会使用内存mq)

构建Spring boot项目,增加依赖项,只需要添加这一项即可


<!-- 添加acitivemq依赖 -->
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-activemq</artifactId>
</dependency>

增加Application类


@SpringBootApplication
@EnableScheduling //使用定时任务发送消息
public class MqTestApplication {
 public static void main(String[] args) {
   SpringApplication.run(MqTestApplication.class, args);
 }
}

配置application.yml


spring:
activemq:
 broker-url: tcp://127.0.01:61616
 packages:
  trust-all: true

构建一个数据Model,可以发送和消费的数据类型有: String, byte array, Map<String,?>, Serializable object.


// 如果发送的消息是一个对象,必须implements Serializable接口
public class TModel implements Serializable {
 private static final long serialVersionUID = -921008687184331557L;
 private int count;
 public TModel(int count) {
   this.count = count;
 }

@Override
 public String toString() {
   return "TModel [count=" + count + "]";
 }

}

构建Producer


@Component
public class Producer {
 // 在Producer中注入JmsTemplate,我们可以通过这个template发送消息
 private final JmsTemplate jmsTemplate;
 private int count = 0;

@Autowired
 public Producer(JmsTemplate jmsTemplate) {
   this.jmsTemplate = jmsTemplate;
 }

// 这里使用Spring Boot的定时任务发送消息
 @Scheduled(fixedRate = 1000)
 public void create() {
   // 使用convertAndSend发送消息
   jmsTemplate.convertAndSend("queue1", new TModel(count++));
 }
}

构建Consumer


@Component
public class Consumer {
 @JmsListener(destination = "queue1")
 public void comsume(TModel content) {
   System.out.println("recive message from queue1 [" + content + "]");
 }
}

特别备注:如果我们的生产者和消费者在不同的Module中时,最好将要消费的数据抽象成公共Module.程序是通过Serializable来序列化和反序列化对象的。必须保证生产者和消费者的对象模型的serialVersionUID是一致的。

项目地址: https://github.com/ldwqh0/active-mq-spring.git

示例:配置rabbitmq ,增加一个队列


@Configuration
public class Aqueue {
@Bean
public Queue queue() {
return new Queue("good");
}

}

定义一个生产者.

当启用activemq之后,会自动创建一个AmqpTemplate ,可以被注入到任何需要的地方,我们可以通过这个AmqpTemplate发送消息到MQ中


/**
* 定义一个生产者
* @author LiDong
*/
@RestController
@RequestMapping("/test")
public class SendController {
@Autowired
private AmqpTemplate template;

@GetMapping
public String testSend() {
// 使用AmqpTemplate发送消息
template.convertAndSend("good", "good");
return "success";
}
}

定义消费者,通过指定RabbitListener(queues='good')指定消费的队列


@Component
public class Consumer {
/**
* 定义一个消费者
* @param message
*/
@RabbitListener(queues = "good")
public void handler(String message) {
System.out.println("recive message from " + message);
}
}

启动测试,在浏览器中输入 http://localhost:8080/test 即可发送一条消息到队列中。 该对列可以被消费者处理

来源:https://www.jianshu.com/p/b95dcc43a8a6

标签:Spring,Boot,ActiveMQ
0
投稿

猜你喜欢

  • Spring Cache手动清理Redis缓存

    2023-11-29 02:49:52
  • Java用freemarker导出word实用示例

    2022-06-05 17:16:32
  • c# wpf如何使用Blend工具绘制Control样式

    2022-10-26 09:35:25
  • Android 通过SQLite数据库实现数据存储管理

    2023-09-28 11:31:59
  • C# 解析XML和反序列化的示例

    2023-02-20 01:16:52
  • C#不重复输出一个数组中所有元素的方法

    2022-07-02 14:25:58
  • Mybatis-Plus 多表联查分页的实现代码

    2023-11-25 04:59:07
  • java语言自行实现ULID过程底层原理详解

    2023-04-13 22:38:50
  • Java Swing组件布局管理器之FlowLayout(流式布局)入门教程

    2021-11-08 05:33:06
  • Java IO异常如何处理详析

    2023-12-04 21:51:29
  • Java手动实现Redis的LRU缓存机制

    2023-07-31 12:51:30
  • SpringCloud Feign转发请求头(防止session失效)的解决方案

    2022-08-29 12:25:59
  • SpringBoot中获取profile的方法详解

    2023-11-19 18:05:00
  • spring循环注入异常问题的解决方案

    2021-06-29 02:21:18
  • java异步编程之一文看完其异步函数表

    2021-12-25 10:57:39
  • JVM 运行时数据区与JMM 内存模型

    2022-08-12 10:49:27
  • Java线程的生命周期命名与获取代码实现

    2022-05-21 05:19:49
  • 使用java实现http多线程断点下载文件(二)

    2021-06-08 04:26:17
  • 详解Spring中的FactoryBean

    2022-06-08 05:29:55
  • Spring Boot日志技术logback原理及配置解析

    2022-09-14 10:51:57
  • asp之家 软件编程 m.aspxhome.com