每日一学:如何在 Spring Boot 整合 RabbitMQ ?

212 阅读3分钟

一、简介

在Spring项目中,可以使用Spring-Rabbit去操作RabbitMQ

尤其是在 spring boot 项目中只需要引入对应的 amqp 启动器依赖即可,方便的使用 RabbitTemplate 发送消息,使用注解接收消息。

一般在开发过程中:

生产者工程:

  1. application.yml 文件配置 RabbitMQ 相关信息;

  2. 在生产者工程中编写配置类,用于创建交换机和队列,并进行绑定

  3. 注入 RabbitTemplate 对象,通过 RabbitTemplate 对象发送消息到交换机 消费者工程:

  4. application.yml 文件配置 RabbitMQ 相关信息

  5. 创建消息处理类,用于接收队列中的消息并进行处理

二、搭建生产者工程

①创建工程

创建生产者工程 springboot-rabbitmq-producer

image.png

image.png

②添加依赖

修改 pom.xml 文件内容为如下:

<?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> 
    <parent> 
        <groupId>org.springframework.boot</groupId> 
        <artifactId>spring-boot-starter-parent</artifactId> 
        <version>2.1.4.RELEASE</version> 
    </parent> 
    <groupId>com.itheima</groupId> 
    <artifactId>springboot-rabbitmq-producer</artifactId> 
    <version>1.0-SNAPSHOT</version> 
        
    <dependencies> 
        <dependency> 
            <groupId>org.springframework.boot</groupId> 
            <artifactId>spring-boot-starter-web</artifactId> 
        </dependency> 
        <dependency> 
            <groupId>org.springframework.boot</groupId> 
            <artifactId>spring-boot-starter-amqp</artifactId> 
        </dependency> 
    </dependencies> 
</project>

③启动类

package com.itheima.rabbitmq; 

import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 

@SpringBootApplication 
public class ProducerApplication { 
    public static void main(String[] args) { 
        SpringApplication.run(ProducerApplication.class); 
    } 
}

④配置RabbitMQ

配置文件

创建 application.yml ,内容如下:

spring: 
    rabbitmq: 
        host: localhost 
        port: 5672 
        virtual-host: /itcast 
        username: caiyo
        password: caiyo

绑定交换机和队列

创建 RabbitMQ 队列与交换机绑定的配置类 com.itheima.rabbitmq.config.RabbitMQConfig

package com.itheima.rabbitmq.config; 

import org.springframework.amqp.core.*; 
import org.springframework.beans.factory.annotation.Qualifier; 
import org.springframework.context.annotation.Bean; 
import org.springframework.context.annotation.Configuration; 

@Configuration 
public class RabbitMQConfig { 
    //交换机名称 
    public static final String ITEM_TOPIC_EXCHANGE = "item_topic_exchange"; 
    
    //队列名称 
    public static final String ITEM_QUEUE = "item_queue"; 
    
    //声明交换机 
    @Bean("itemTopicExchange") 
    public Exchange topicExchange(){ 
        return ExchangeBuilder.topicExchange(ITEM_TOPIC_EXCHANGE).durable(true).build(); 
    }
    
    //声明队列 
    @Bean("itemQueue") 
    public Queue itemQueue(){ 
        return QueueBuilder.durable(ITEM_QUEUE).build(); 
    }
    
    //绑定队列和交换机 
    @Bean 
    public Binding itemQueueExchange(@Qualifier(
            "itemQueue") Queue queue, @Qualifier("itemTopicExchange") Exchange exchange){
        return BindingBuilder.bind(queue).to(exchange).with("item.#").noargs(); 
    } 
}

⑤消息发送Controller

我们创建一个SpringMVC的Controller方便我们进行测试

package com.itheima.rabbitmq.controller; 

import com.itheima.rabbitmq.config.RabbitMQConfig; 
import org.springframework.amqp.rabbit.core.RabbitTemplate; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.web.bind.annotation.GetMapping; 
import org.springframework.web.bind.annotation.RequestParam; 
import org.springframework.web.bind.annotation.RestController; 

/**
 * 发送消息的测试类 
*/ 
@RestController 
public class SendMsgController { 
    //注入RabbitMQ的模板 
    @Autowired 
    private RabbitTemplate rabbitTemplate; 
    
    /**
     * 测试 
    */ 
    @GetMapping("/sendmsg") 
    public String sendMsg(@RequestParam String msg, @RequestParam String key){ 
        /**
         * 发送消息 
         * 参数一:交换机名称 
         * 参数二:路由key 
         * 参数三:发送的消息 
        */ 
        rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE ,key ,msg); 
        //返回消息 return "发送消息成功!"; 
    } 
}

三、搭建消费者工程

①创建工程

创建消费者工程 springboot-rabbitmq-consumer

image.png

image.png

②添加依赖

修改 pom.xml 文件内容为如下:

<?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> 
    <parent>
         <groupId>org.springframework.boot</groupId> 
         <artifactId>spring-boot-starter-parent</artifactId> 
         <version>2.1.4.RELEASE</version> 
    </parent> 
        
    <groupId>com.itheima</groupId> 
    <artifactId>springboot-rabbitmq-consumer</artifactId> 
    <version>1.0-SNAPSHOT</version> 
    
    <dependencies> 
        <dependency> 
            <groupId>org.springframework.boot</groupId> 
            <artifactId>spring-boot-starter-web</artifactId> 
        </dependency> 
    
        <dependency> 
            <groupId>org.springframework.boot</groupId> 
            <artifactId>spring-boot-starter-amqp</artifactId> 
        </dependency> 
    </dependencies>
</project>

③启动类

package com.itheima.rabbitmq; 

import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 

@SpringBootApplication 
public class ConsumerApplication { 
    public static void main(String[] args) { 
        SpringApplication.run(ConsumerApplication.class); 
    } 
}

④配置RabbitMQ

创建 application.yml ,内容如下:

spring: 
    rabbitmq: 
        host: localhost 
        port: 5672 
        virtual-host: /itcast 
        username: caiyo
        password: caiyo

⑤消息监听处理类

编写消息监听器 com.itheima.rabbitmq.listener.MyListener

package com.itheima.rabbitmq.listener; 

import org.springframework.amqp.rabbit.annotation.RabbitListener; 
import org.springframework.stereotype.Component; 

@Component 
public class MyListener { 
    /**
     * 监听某个队列的消息 
     * @param message 接收到的消息 
    */ 
    
    @RabbitListener(queues = "item_queue") 
    public void myListener1(String message){
        System.out.println("消费者接收到的消息为:" + message); 
    } 
}

⑥测试

image.png

在生产者工程 springboot-rabbitmq-producer 中创建测试类,发送消息:

package com.itheima.rabbitmq; 

import com.itheima.rabbitmq.config.RabbitMQConfig; 
import org.junit.Test; 
import org.junit.runner.RunWith; 
import org.springframework.amqp.rabbit.core.RabbitTemplate; 
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 RabbitMQTest { 

    @Autowired 
    private RabbitTemplate rabbitTemplate; 
    
    @Test 
    public void test(){ 
        rabbitTemplate.convertAndSend(
            RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
                "item.insert", "商品新增,routing key 为item.insert"); 
        rabbitTemplate.convertAndSend(
            RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
                "item.update", "商品修改,routing key 为item.update"); 
        rabbitTemplate.convertAndSend(
            RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
                "item.delete", "商品删除,routing key 为item.delete"); 
    }
}

先运行上述测试程序(交换机和队列才能先被声明和绑定),然后启动消费者;在消费者工程 springboot-rabbitmq-consumer 中控制台查看是否接收到对应消息。

另外,也可以在RabbitMQ的管理控制台中查看到交换机与队列的绑定:

image.png