RabbitMQ(四)

embedded/2025/1/17 6:09:31/

SpringBoot整合RabbitMQ

  • SpringBoot整合
    • 1、生产者工程
      • ①创建module
      • ②配置POM
      • ③YAML
      • ④主启动类
      • ⑤测试程序
    • 2、消费者工程
      • ①创建module
      • ②配置POM
      • ③YAML
        • 文件内配置:
      • ④主启动类
      • ⑤监听器
    • 3、@RabbitListener注解属性对比
      • ①bindings属性
      • ②queues属性

SpringBoot整合

1、生产者工程

①创建module

在这里插入图片描述

②配置POM

添加如下依赖:

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

③YAML

spring: rabbitmq: host: 192.168.xxx.xxxport: 5672 username: guest password: 123456 virtual-host: /

④主启动类

package com.xxx.mq;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** @ClassName: RabbitMQProducerMainType* @Package: com.xxx.mq* @Author: * @CreateDate: * @Version: V1.0.0* @Description:*/@SpringBootApplication
public class RabbitMQProducerMainType {public static void main(String[] args) {SpringApplication.run(RabbitMQProducerMainType.class, args);}}

⑤测试程序

在src目录下的test目录内新建测试类:

package com.xxx.mq.test;import org.junit.jupiter.api.Test;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;/*** @ClassName: RabbitMQTest* @Package: com.xxx.mq.test* @Author: * @CreateDate: * @Version: V1.0.0* @Description:*/@SpringBootTest
public class RabbitMQTest {public static final String EXCHANGE_DIRECT = "exchange.direct.order";public static final String ROUTING_KEY = "order";@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void test01SendMessage() {rabbitTemplate.convertAndSend(EXCHANGE_DIRECT, ROUTING_KEY, "Hello Rabbit!SpringBoot!");}}

2、消费者工程

①创建module

在这里插入图片描述

②配置POM

添加如下依赖:

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies>

③YAML

增加日志打印的配置:
在这里插入图片描述
新建名为application的yml文件。

文件内配置:
spring:rabbitmq:host: 192.168.xxx.xxxport: 5672username: guestpassword: 123456virtual-host: /
logging:level:com.xxx.mq.listener.MyMessageListener: info

将host修改为自己的地址。

④主启动类

package com.xxx.mq;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** @ClassName: RabbitMQConsumerMainType* @Package: com.xxx.mq* @Author: * @CreateDate: * @Version: V1.0.0* @Description:*/@SpringBootApplication
public class RabbitMQConsumerMainType {public static void main(String[] args) {SpringApplication.run(RabbitMQConsumerMainType.class, args);}}

⑤监听器

新建子包listener,并编写监听类:

package com.xxx.mq.listener;import com.rabbitmq.client.Channel;
import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;/*** @ClassName: MyMessageListener* @Package: com.xxx.mq.listener* @Author: * @CreateDate: * @Version: V1.0.0* @Description:*/@Component
@Slf4j
public class MyMessageListener {public static final String EXCHANGE_DIRECT = "exchange.direct.order";public static final String ROUTING_KEY = "order";public static final String QUEUE_NAME = "queue.order";//    写法一:监听 + 在 RabbitMQ 服务器上创建交换机、队列@RabbitListener(bindings = @QueueBinding(value = @Queue(value = QUEUE_NAME, durable = "true"),exchange = @Exchange(value = EXCHANGE_DIRECT),key = {ROUTING_KEY}))
//    写法二:监听
//    @RabbitListener(queues = {QUEUE_NAME})public void processMessage(String dataString, Message message, Channel channel) {log.info("消费端接收到了消息:" + dataString);}
}

3、@RabbitListener注解属性对比

①bindings属性

  • 表面作用:
    • 指定交换机和队列之间的绑定关系
    • 指定当前方法要监听的队列
  • 隐藏效果:如果RabbitMQ服务器上没有这里指定的交换机和队列,那么框架底层的代码会创建它们

②queues属性

@RabbitListener(queues = {QUEUE_TEST})
  • 作用:指定当前方法要监听的队列
  • 注意:此时框架不会创建相关交换机和队列,必须提前创建好

先启动生产者端代码,此时会立即执行完成。然后执行消费者端代码,等待消息。
在生产者端module下的test内有创建好的测试代码,执行test01SendMessage测试方法,结果如图所示:
在这里插入图片描述
在这里插入图片描述
可以看到收到了生产者测试代码中的消息。前面的报错是因为我先启动了消费者端代码,此时找不到对应的交换机以及消息队列,当启动生产者端代码后就不会报错了,可以正确的接收到消息。


http://www.ppmy.cn/embedded/154577.html

相关文章

解决 Mac 系统上的 node-sass 问题

解决 Mac 系统&#xff08;尤其是 M1/M2&#xff09;上的 node-sass 问题 问题描述 在 Mac 系统上使用 node-sass 时&#xff0c;经常会遇到以下错误&#xff1a; Node Sass does not yet support your current environment: OS X 64-bit with Unsupported runtime (108)或者…

java 迪米特法则,原理、思想、工作流程、实现细节、稳定性、优缺点、应用场景等

迪米特法则&#xff08;Law of Demeter&#xff0c;LoD&#xff09;&#xff0c;也被称为“最少知识原则”&#xff0c;是一种指导面向对象设计的原则&#xff0c;旨在减少对象之间的耦合度。以下是对迪米特法则的详细解析。 1. 定义 迪米特法则指出&#xff1a;一个对象应该…

鸿蒙中选择地区

1.首页ui import { CustomDialogExampleSelectRegion } from ./selectRegion/SelectRegionDialog;Entry Component struct Index {State selectedRegion: string 选择地区// 地区dialogControllerSelectRegion: CustomDialogController | null new CustomDialogController({b…

栈算法篇——LIFO后进先出,数据与思想的层叠乐章(下)

文章目录 前言第一章&#xff1a;比较含退格的字符串1.1 题目链接&#xff1a;https://leetcode.cn/problems/backspace-string-compare/description/1.2 题目分析&#xff1a;1.3 思路讲解&#xff1a;1.4 代码实现&#xff1a; 第二章&#xff1a;基本计算器||2.1 题目链接&a…

期权懂|场内期权合约行权价格是如何设定制度的?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 场内期权合约行权价格是如何设定制度的&#xff1f; 场内期权合约的行权价格是期权合约中的一个关键要素&#xff0c;它决定了期权买方在期权到期日或之前买入&#xff08;对于…

使用DAS的导出和导入功能迁移GaussDB数据

使用DAS的导出和导入功能迁移GaussDB数据 操作场景 数据管理服务&#xff08;Data Admin Service&#xff0c;简称DAS&#xff09;是用来登录和操作华为云上数据库的Web服务&#xff0c;提供数据库开发、运维、智能诊断的一站式云上数据库管理平台&#xff0c;方便用户使用和…

网管平台(进阶篇):路由器的管理实践

在当今数字化时代&#xff0c;路由器作为网络连接的核心设备&#xff0c;其管理对于确保网络的稳定、高效和安全至关重要。本文旨在深入探讨路由器管理的重要性、基本设置步骤、高级功能配置以及日常维护&#xff0c;帮助读者构建一个高效且安全的网络环境。 一、路由器管理的…

服务器数量多迁移麻烦怎么办?

很多体量大的企业在迁移的过程中如果使用传统得迁移方式会非常的不方便&#xff0c;那么有没有什么可以做到批量式迁移服务器呢&#xff1f;华为云迁移中心&#xff08;Migration Center, MgC&#xff09;是华为云提供的一站式迁移和现代化平台&#xff0c;承载华为云迁移方法论…