首页 > 其他分享 >Spring Boot中的消息队列集成

Spring Boot中的消息队列集成

时间:2023-09-23 10:03:59浏览次数:28  
标签:队列 Spring Boot 消息 spring message

介绍

在现代应用程序中,消息队列已经成为了一种非常流行的解决方案,它可以帮助我们实现异步通信、解耦和扩展性。Spring Boot提供了对多种消息队列的集成支持,包括RabbitMQ、Kafka、ActiveMQ等。在本文中,我们将深入探讨Spring Boot中的消息队列集成。

RabbitMQ集成

RabbitMQ是一个流行的开源消息队列,它支持多种消息协议,包括AMQP、STOMP、MQTT等。在Spring Boot中,我们可以使用spring-boot-starter-amqp模块来集成RabbitMQ。

添加依赖

在pom.xml文件中添加以下依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

配置连接

在application.properties文件中添加以下配置:

spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest

发送消息

在发送消息的类中,我们可以使用RabbitTemplate来发送消息:

@Autowired
private RabbitTemplate rabbitTemplate;

public void sendMessage(String message) {
  rabbitTemplate.convertAndSend("exchange", "routingKey", message);
}

接收消息

在接收消息的类中,我们可以使用@RabbitListener注解来监听消息:

@RabbitListener(queues = "queue")
public void receiveMessage(String message) {
  System.out.println("Received message: " + message);
}

Kafka集成

Kafka是一个高性能、分布式的消息队列,它支持多种消息协议,包括Kafka协议、Avro协议等。在Spring Boot中,我们可以使用spring-kafka模块来集成Kafka。

添加依赖

在pom.xml文件中添加以下依赖:

<dependency>
  <groupId>org.springframework.kafka</groupId>
  <artifactId>spring-kafka</artifactId>
</dependency>

配置连接

在application.properties文件中添加以下配置:

spring.kafka.bootstrap-servers=localhost:9092
spring.kafka.consumer.group-id=group1
spring.kafka.consumer.auto-offset-reset=earliest

发送消息

在发送消息的类中,我们可以使用KafkaTemplate来发送消息:

@Autowired
private KafkaTemplate<String, String> kafkaTemplate;

public void sendMessage(String message) {
  kafkaTemplate.send("topic", message);
}

接收消息

在接收消息的类中,我们可以使用@KafkaListener注解来监听消息:

@KafkaListener(topics = "topic")
public void receiveMessage(String message) {
  System.out.println("Received message: " + message);
}

ActiveMQ集成

ActiveMQ是一个流行的开源消息队列,它支持多种消息协议,包括AMQP、STOMP、OpenWire等。在Spring Boot中,我们可以使用spring-boot-starter-activemq模块来集成ActiveMQ。

添加依赖

在pom.xml文件中添加以下依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-activemq</artifactId>
</dependency>

配置连接

在application.properties文件中添加以下配置:

spring.activemq.broker-url=tcp://localhost:61616
spring.activemq.user=admin
spring.activemq.password=admin

发送消息

在发送消息的类中,我们可以使用JmsTemplate来发送消息:

@Autowired
private JmsTemplate jmsTemplate;

public void sendMessage(String message) {
  jmsTemplate.convertAndSend("queue", message);
}

接收消息

在接收消息的类中,我们可以使用@JmsListener注解来监听消息:

@JmsListener(destination = "queue")
public void receiveMessage(String message) {
  System.out.println("Received message: " + message);
}

总结

Spring Boot提供了对多种消息队列的集成支持,我们可以根据自己的需求选择合适的消息队列。在使用消息队列时,我们需要注意消息的可靠性、幂等性等问题,以保证系统的稳定性和可靠性。

标签:队列,Spring,Boot,消息,spring,message
From: https://blog.51cto.com/u_16266017/7575762

相关文章

  • BootstrapBlazor组件库,Table组件外部导出数据
    BootstrapBlazor组件库,Table组件导出选中行数据问题描述有很多小伙伴在使用BootstrapBlazor组件库的Table组件导出功能时,不知道怎么通过外部按钮来导出数据。解决方案通过@ref当前表格对象来获取数据,然后进行导出操作。Razor代码<Buttonclass="mb-2"Text="导出Table数据"......
  • 干货,某大厂小姐姐深夜让我说出了秘密-springboot发邮件
    后端依赖<!--引入mail依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-mail</artifactId></dependency><!--使用thymeleaf构建邮件模板--><depen......
  • SpringMVC如何在web.xml中配置DispatcherServlet
    SpringMVC如何在web.xml中配置DispatcherServlet配置WEB-INF/web.xml===>配置前端控制器/中央控制器/分发控制器,用户所有的请求都会经过它的处理<?xmlversion="1.0"encoding="UTF-8"?><web-appxmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi......
  • SpringCloud-ZipKin搭建保姆级教程
    服务链路追踪一、服务追踪说明微服务架构是通过业务来划分服务的,使⽤REST调⽤。对外暴露的⼀个接⼝,可能需要很多个服务协同才能完成这个接⼝功能,如果链路上任何⼀个服务出现问题或者⽹络超时,都会形成导致接⼝调⽤失败。随着业务的不断扩张,服务之间互相调⽤会越来越复杂,......
  • springCloud
     一、Eureka服务注册与发现 eureka是ap原则,注重服务的可用性(不会挂,只是数据可能会不一致)zookeeper是cp原则,注重数据的一致性(当一个接点挂了,在几分钟内就不能访问了) 一、创建eureka的server服务端1、创建eureka注意pom.xml文件中的spring-boot的版本要与spring-cl......
  • 【Spring使用三级缓存解决循环依赖的过程】
    testService1和testService2相互依赖当Spring创建testService1对象时,它会先从一级缓存中查找是否存在testService1的实例。如果缓存中不存在testService1实例,它将继续查找二级缓存中是否存在testService1。如果二级缓存中也不存在testService1实例,则Spring会尝试从三级缓存中获取......
  • [SpringSecurity5.6.2源码分析十三]:LogoutFilter
    前言• SpringSecurity默认提供了登录的页面以及登录的接口,与之对应的也提供了登出页和登出请求• 登出请求对应的过滤器是LogoutFilter• 登出页对应的是DefaultLogoutPageGeneratingFilter、1.LogoutConfigurer• LogoutConfigurer是LogoutFilter对应的配置类,先看其主要方法......
  • BootstrapBlazor组件库,Table组件导出选中行数据
    BootstrapBlazor组件库,Table组件导出选中行数据问题描述有很多小伙伴在使用BootstrapBlazor组件库的Table组件导出功能时,不知道怎么导出选中的行数据。解决方案通过SelectedRows来导出选中的行数据。Razor代码<TableTItem="Foo"IsPagination="true"PageItemsSource="Pag......
  • SpringSecurity用户登录限制
    本次给你介绍只允许用户在一个地方登录,也就是说每个用户只允许有一个Session。他有两种场景如果同一个用户在第二个地方登录,则将第一个登录下线如果同一个用户在第二个地方登录,则不允许二次的登录同一个用户在第二个地方登录,则将第一个登录退出具体步骤如下:重构com.security.learn.......
  • JeecgBoot v3.5.5 版本发布,性能大升级版本—开源免费的低代码开发平台
    项目介绍JeecgBoot是一款企业级的低代码平台!前后端分离架构SpringBoot2.x,SpringCloud,AntDesign&Vue3,Mybatis-plus,Shiro,JWT支持微服务。强大的代码生成器让前后端代码一键生成!JeecgBoot引领低代码开发模式(OnlineCoding->代码生成->手工MERGE),帮助解决Java项目70%的重复......