SpringBoot与消息队列

本文介绍了SpringBoot如何使用JMS(ActiveMQ)、AMQP(RabbitMQ)和KafKa进行消息收发。详细讲解了各个组件的配置、消息转换器的使用,并提供了代码示例。内容涵盖JMS的基本概念、AMQP与JMS的区别、RabbitMQ的发送与接收、KafKa的集成及监听消息方式。
摘要由CSDN通过智能技术生成

Spring与消息队列

一、SpringBoot使用JMS

1、什么是JMS

JMS是java的一个标准,定义了使用消息代理的通用API,相当于JDBC,让java使用基于消息的异步通讯更加简单。

2、使用ActiveMQ收发消息

控制台地址(http://localhost:8161/admin/)

producer端:

添加依赖:

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

编写配置:

spring:
  #使用的消息队列类型
  activemq:
    #链接消息代理的协议ip和端口
    broker-url: tcp://localhost:61616
    #链接代理的用户名密码
    user: admin
    password: admin
    #是否开启内存代理 如果不是同一个程序收发消息 则选择false默认true
    in-memory: false
  #jms设置
  jms:
  	#模板设置
    template:
      #设置默认主题
      default-destination: testmq

编写代码:

@RestController
public class producerController {
   
    //依赖注入JmsTemplate
    @Autowired
    private JmsTemplate jmsTemplate;

    @PostMapping(value = "/message")
    public ResponseEntity<String> message(@RequestParam("msg") String msg){
   
        //使用JmsTemplate的send方法发送消息
        jmsTemplate.send((session)->{
   
            return session.createObjectMessage(msg);
        });
        return ResponseEntity.ok(msg);
    }
}

这里send方法有很多重载,使用默认的send方法则将消息发送到默认主题,也就是配置文件中配置的默认主题。也可以自行指定主题。

consumer端:

添加依赖:

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

编写配置:

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

编写代码:

@Service
public class consumerService {
   
    @JmsListener(destination = "testmq")
    public void getMessage(String msg){
   
        System.out.println("--->" + msg);
    }
}

这里使用的是监听模式(推送模式)来收取消息,也可以编码手动接收(拉取模式)来接收消息,按照需求进行选择。拉去模式是消息驱动的,只需要在接收消息的方法上添加@JmsListener注解,设置感兴趣的topic即可。

3、遇到的问题

1、这里需要注意,如果监听的方法有返回值,则会抛出异常,无法寻找到主题。异常信息如下。

Failed to send reply with payload [test]; nested exception is javax.jms.InvalidDestinationException: Cannot determine response destination: Request message does not contain reply-to destination, and no default response destination set.

2、如果使用send方法发送领域对象,接收端需要手动进行转换,转换之前需要在容器中注入MessageConverter(springboot2.5.4中居然没有自动注入)。

3、使用SimpleMessageConverter进行转换时,转换的对象必须和发送时的对象全限定名一样,可以将领域对象打包发送到mvn仓库再进行引入。

4、如何使用send方法发送一个对象:

首先选择要使用的消息转换器并进行配置,这里使用MappingJackson2MessageConverter。

@Bean
public MappingJackson2MessageConverter messageConverter(){
   
    //创建新的消息转换器
    MappingJackson2MessageConverter converter = new MappingJackson2MessageConverter();
    //设置标识类型的属性->也就是添加一个属性到mes
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 集成消息队列主要是为了简化在 Spring Boot 应用中处理异步通信和解耦复杂系统的设计。Spring Boot 提供了对多个主流消息中间件(如 RabbitMQ、Apache Kafka、ActiveMQ 等)的高度集成支持。 以下是使用 Spring Boot 集成消息队列的基本步骤: 1. **添加依赖**:在你的 Maven 或 Gradle 项目中,添加对应消息队列(如 Spring Cloud Stream 或者 Spring AMQP)的依赖。 ```xml <!-- Maven --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> <!-- Gradle --> implementation 'org.springframework.boot:spring-boot-starter-amqp' ``` 2. **配置消息驱动器**:配置连接到消息服务器的属性,包括主机名、端口、用户名、密码等。 3. **创建消息组件**:定义消息生产者(Producer)和消费者(Consumer)。生产者通常用于发送消息到队列,而消费者则从队列中接收并处理消息。 ```java @Service public class MessageProducer { @Autowired private AmqpTemplate amqpTemplate; public void sendMessage(String message) { // 使用amqpTemplate发送消息 } } @Service public class MessageConsumer { @RabbitListener(queues = "myQueue") public void consumeMessage(String message) { // 处理接收到的消息 } } ``` 4. **声明消息队列**:如果消息队列不存在,可以在启动应用时自动创建。可以通过 `@Bean` 注解或 XML 配置文件声明。 5. **使用消息模板**:Spring提供了诸如`AmqpTemplate`、`KafkaTemplate`等模板类,它们抽象了发送和接收消息的细节,使代码更简洁。 6. **错误处理和断路器**:考虑设置适当的操作超时和错误重试策略,以及可能使用的断路器模式,如 Hystrix。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值