RabbitMQ 第一天 基础 6 SpringBoot 整合RabbitMQ
RabbitMQ
【黑马程序员RabbitMQ全套教程,rabbitmq消息中间件到实战】
文章目录
- RabbitMQ
- 第一天 基础
- 6 SpringBoot 整合RabbitMQ
- 6.1 SpringBoot 整合 RabbitMQ【生产者】
- 6.1.1 生产者
- 6.2 SpringBoot 整合 RabbitMQ【消费者】
- 6.2.1 消费者
- 6.3 小结
第一天 基础
6 SpringBoot 整合RabbitMQ
6.1 SpringBoot 整合 RabbitMQ【生产者】
6.1.1 生产者
- 创建生产者SpringBoot工程
好家伙,老师居然用手工 创建…
那我也…
直接创建
OK,自己导坐标吧
<?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><groupId>com.dingjiaxiong</groupId><artifactId>producer-springboot</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.4.RELEASE</version></parent><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></project>
OK, 这就是一个 SpringBoot 工程模块了
- 引入start,依赖坐标
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
OK,上一步 一块儿搞了
- 编写yml配置,基本信息配置
spring:rabbitmq:host: xxxxxxxxxxxx # 记得改成自己的服务器IPusername: guestpassword: guestport: 5672virtual-host: /
这里就没用自己的用户了,感觉这节课 是很久之后,黑马老师补录的
来一个启动类
package com.dingjiaxiong;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** ClassName: ProducerApplication* date: 2022/11/16 17:00** @author DingJiaxiong*/@SpringBootApplication
public class ProducerApplication {public static void main(String[] args) {SpringApplication.run(ProducerApplication.class);}}
OK
- 定义交换机,队列以及绑定关系的配置类
package com.dingjiaxiong.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;/*** ClassName: RabbitMQConfig* date: 2022/11/16 17:02** @author DingJiaxiong*/@Configuration
public class RabbitMQConfig {public static final String EXCHANGE_NAME = "boot_topic_exchange";public static final String QUEUE_NAME = "boot_queue";//1. 交换机@Bean("bootExchange")public Exchange bootExchange(){return ExchangeBuilder.topicExchange(EXCHANGE_NAME).durable(true).build();}//2. Queue 队列@Bean("bootQueue")public Queue bootQueue(){return QueueBuilder.durable(QUEUE_NAME).build();}//3. 队列和交换机的绑定关系@Beanpublic Binding bindQueueExchange(@Qualifier("bootQueue") Queue queue,@Qualifier("bootExchange") Exchange exchange){return BindingBuilder.bind(queue).to(exchange).with("boot.#").noargs();}}
- 注入RabbitTemplate,调用方法,完成消息发送
直接测试类
package com.dingjiaxiong.test;import com.dingjiaxiong.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;/*** ClassName: ProducerTest* date: 2022/11/16 17:11** @author DingJiaxiong*/@SpringBootTest
@RunWith(SpringRunner.class)
public class ProducerTest {//1. 注入RabbitTemplate@Autowiredprivate RabbitTemplate rabbitTemplate;@Testpublic void testSend(){rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME,"boot.haha","boot mq hello");}}
OK,一切准备就绪,直接运行
OK,绿了
查看管控台【记得 换成 guest 用户】
交换机创建 成功
队列 也创建完成了,而且还有一条消息在里面
拿一下
没问题
【这就是生产者 了】
6.2 SpringBoot 整合 RabbitMQ【消费者】
6.2.1 消费者
【消费者】
- 创建消费者SpringBoot工程
终于想到Spring Initializr 了
下一步
这个版本就太高了… 一会儿 换一个【笔者这里 2022年11月16日,Boot 版本是2.7.5,老师是2.1.7 …】
依赖都不要,直接创建
OK,一个全新的SpringBoot 工程 模块
换一下版本 吧,和生产者 一致些
记得刷一下
- 引入start,依赖坐标
OK,就这样吧
- 编写yml配置,基本信息配置
直接复制 生产者 的
spring:rabbitmq:host: xxxxxxxxxxxxx # 记得改成自己的服务器IPusername: guestpassword: guestport: 5672virtual-host: /
- 定义监听类,使用@RabbitListener注解完成队列监听。
package com.dingjiaxiong.listener;import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;/*** ClassName: RabbitMQListener* date: 2022/11/16 17:28** @author DingJiaxiong*/@Component
public class RabbitMQListener {@RabbitListener(queues = "boot_queue")public void ListenerQueue(Message message){System.out.println(message);}}
OK,现在 的队列 里面还有一条 消息,直接启动消费者
OK,这样就拿到了
查看管控台
消息已经被消费了 ,欧克欧克【这就是 SpringBoot 整合RabbitMQ 了】
6.3 小结
- SpringBoot提供了快速整合RabbitMQ的方式
- 基本信息再yml中配置,队列交互机以及绑定关系在配置类中使用Bean的方式配置
- 生产端直接注入RabbitTemplate完成消息发送
- 消费端直接使用@RabbitListener完成消息接收
RabbitMQ 第一天 基础 6 SpringBoot 整合RabbitMQ相关推荐
- RabbitMQ(八):SpringBoot 整合 RabbitMQ(三种消息确认机制以及消费端限流)
说明 本文 SpringBoot 与 RabbitMQ 进行整合的时候,包含了三种消息的确认模式,如果查询详细的确认模式设置,请阅读:RabbitMQ的三种消息确认模式 同时消费端也采取了限流的措施, ...
- rabbitmq学习第6节--SpringBoot整合rabbitMQ
文章目录 1.生产者端的配置 1.1 yml配置文件 1.2 消息体对象 1.3 生产者服务类 1.4 测试类 2. 消费者端的配置 2.1 yml配置文件 2.2 消息体对象 2.3 消费者服务类 ...
- Springboot整合RabbitMQ,包含direct,topic,fanout三种模式的整合
一 RabbitMQ的介绍 RabbitMQ是消息中间件的一种,消息中间件即分布式系统中完成消息的发送和接收的基础软件.这些软件有很多,包括ActiveMQ(apache公司的),RocketMQ(阿 ...
- RabbitMQ,RabbitMQ 的工作模式,Spring 整合 RabbitMQ,Springboot 整合RabbitMQ
什么是RabbitMQ 1.1 MQ概述 MQ全称 Message Queue(消息队列),是在消息的传输过程中保存消息的容器.多用于分布式系统之间进行通信. ⚫ MQ,消息队列,存储消息的中间件 ⚫ ...
- 九、springboot整合rabbitMQ
springboot整合rabbitMQ 简介 rabbitMQ是部署最广泛的开源消息代理. rabbitMQ轻量级,易于在内部和云中部署. 它支持多种消息传递协议. RabbitMQ可以部署在分布式 ...
- Spring Boot---(10)SpringBoot整合RabbitMQ
请参考:Spring Boot---(24)springboot整合RabbitMQ 由于docker安装非常方便,这里就用docker来安装和启动了.没接触过docker的可以参考这里:零基础学习D ...
- SpringBoot整合RabbitMQ(包含生产者和消费者)
生产者 创建一个SpringBoot项目springboot-producer,作为RabbitMQ的生产者. 在pom文件中引入相关的依赖坐标 <dependency><group ...
- Springboot 整合RabbitMq ,用心看完这一篇就够了
该篇文章内容较多,包括有rabbitMq相关的一些简单理论介绍,provider消息推送实例,consumer消息消费实例,Direct.Topic.Fanout的使用,消息回调.手动确认等. (但是 ...
- RabbitMQ消息队列(六):SpringBoot整合之通配符模式
RabbitMQ消息队列(六):SpringBoot整合之通配符模式 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AeZQrNHS-1660220618697)(E: ...
最新文章
- Id选择器和Class选择器
- 很有必要看,这篇 解决 IndexError: list index out of range
- enumerate()函数用法
- CentOS下KVM网卡设置成网桥时获取镜像端口的流量
- .bashrc文件在哪?
- Mysql Too many connections解决方法
- java如何遍历combobox_如何通过COMBOBOX设置Java中的框架标题?
- Python模拟决赛现场最终得分计算过程
- 独立站引流真的那么难吗?
- 数学建模之相关性分析1
- python成绩统计_巧用python对学生成绩计算总分并排序
- Quartus II 安装
- 数字签名(Digital Signature)
- 精品餐饮业奢华西餐专业PPT-朴尔PPT
- 0-1背包问题和部分背包(fractional knapsack)问题分析(动态规划,贪心算法)
- Ext中TextField的 label和feild的间距的设定
- 模拟手机端来爬取数据
- win10计算机无法使用网络资源管理器,win10无法显示可用网络怎么办
- c语言弹出窗口的函数名,用C语言做弹出窗口
- lambdaquerywrapper in使用样例
热门文章
- MySQL的幻读是怎么被解决的?
- 如何显示隐藏的文件夹
- 武汉星起航跨境:美元汇率上升,旺季爆单,美国站卖家迎来好消息
- Mobile-Former来了!微软提出:MobileNet+Transformer轻量化并行网络
- Gem5与NVMain混合编译(一)
- 中国海洋大学计算机博士毕业要求,博士按时毕业不到四成 延长学制促慎重决定...
- 研发效能怎么分析?方法论、模型、误区都在这里了
- Android Custom
- [Q] google map 和 google earth pro 3d模式 黑屏
- 家国梦自动收取金币、货物、升级建筑、拆相册等脚本