当前位置: 首页 > news >正文

RabbitMQ快速入门(简单收发消息)

文章目录

  • 前言
  • 一、数据隔离
    • 1.用户管理
    • 2.virtual host
  • 二、控制台收发
    • 1.交换机
    • 2.队列
    • 3.绑定
  • 三、编程式收发
    • 1.依赖和配置
    • 2.收发信息
  • 总结


前言

1.了解数据隔离
2.RabbitMQ控制台收发信息
3.SpringBoot整合RabbitMQ收发信息


一、数据隔离

1.用户管理

点击Admin选项卡,首先会看到RabbitMQ控制台的用户管理界面

在这里插入图片描述
这里的用户都是RabbitMQ的管理或运维人员。仔细观察用户表格中的字段,如下:

  • Name:itheima,也就是用户名
  • Tags:administrator,说明itheima用户是超级管理员,拥有所有权限
  • Can access virtual host: /,可以访问的virtual host,这里的/是默认的virtual host

对于小型企业而言,出于成本考虑,我们通常只会搭建一套MQ集群,公司内的多个不同项目同时使用。这个时候为了避免互相干扰, 我们会利用virtual host的隔离特性,将不同项目隔离。一般会做两件事情:

  • 给每个项目创建独立的运维账号,将管理权限分离。
  • 给每个项目创建不同的virtual host,将每个项目的数据隔离。 比如,我们给自己项目创建一个新的用户,命名为dragon,权限为admin

在这里插入图片描述

2.virtual host

创建完用户,你会发现你的用户是这样:
在这里插入图片描述
别急,需要授权,为你创建的用户绑定管理的虚拟机。登录你刚才创建的用户。
在这里插入图片描述
/代表默认虚拟机,我们可以给自己的项目创建一个单独的virtual host,而不是使用默认的/。

在这里插入图片描述
由于我们是登录dragon账户后创建的virtual host,因此回到users菜单,你会发现当前用户已经具备了对/dragon这个virtual host的访问权限了
在这里插入图片描述
如果你以前在默认的用户或者你创建的其他用户创建了队列,交换机,你可以看到全部没有,这就是隔离效果,互不干扰。就在当前用户当前绑定授权的虚拟机操作。

二、控制台收发

如果RabbitMQ安装有问题,可以看我文章Docker中的快速安装RaabbitMQ

1.交换机

点击Exchanges选项卡,可以看出很多交换机

在这里插入图片描述

我们点击任意交换机,即可进入交换机详情页面。仍然会利用控制台中的publish message 发送一条消息:

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

这里是由控制台模拟了生产者发送的消息(这里的生产者就是交换机),可以看到拒绝了,这样说明交换机没有存储消息的能力,由于没有消费者存在,最终消息丢失了。交换机只负责路由分发消息,所以我们创建队列,也就是消费者来处理接收消息,让交换机(生产者)有分发消息的对象。

2.队列

我们打开Queues选项卡,新建一个队列:hello.queue1、hello.queue2

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

此时,我们再次向amq.fanout交换机发送一条消息。会发现消息依然没有到达队列!!
怎么回事呢?
发送到交换机的消息,只会路由到与其绑定的队列,因此仅仅创建队列是不够的,我们还需要将其与交换机绑定。

3.绑定

点击Exchanges选项卡,点击amq.fanout交换机,进入交换机详情页,然后点击Bindings菜单,在表单中填写要绑定的队列名称

在这里插入图片描述

再次进入绑定队列的交换机内发送信息,回到Queues页面,可以发现hello.queue中已经有一条消息了

在这里插入图片描述

点击队列名称,进入详情页,查看队列详情,这次我们点击get message,可以看到信息了

在这里插入图片描述
在这里插入图片描述

三、编程式收发

  • 将来我们开发业务功能的时候,肯定不会在控制台收发消息,而是应该基于编程的方式。由于RabbitMQ采用了AMQP协议,因此它具备跨语言的特性。任何语言只要遵循AMQP协议收发消息,都可以与RabbitMQ交互。并且RabbitMQ官方也提供了各种不同语言的客户端。但是,RabbitMQ官方提供的Java客户端编码相对复杂,一般生产环境下我们更多会结合Spring来使用。而Spring的官方刚好基于RabbitMQ提供了这样一套消息收发的模板工具:SpringAMQP。并且还基于SpringBoot对其实现了自动装配,使用起来非常方便。
  • SpringAMQP提供了三个功能:
    • 自动声明队列、交换机及其绑定关系
    • 基于注解的监听器模式,异步接收消息
    • 封装了RabbitTemplate工具,用于发送消息

1.依赖和配置

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.12</version><relativePath/></parent><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency><!--AMQP依赖,包含RabbitMQ--><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>
spring:rabbitmq:host: 192.168.198.148 # 你的虚拟机IPport: 5673 # 端口virtual-host: /dragon # 虚拟主机username: dragon # 用户名password: 123 # 密码

2.收发信息

这里是创建两个springboot项目,在途中pom.xml文件粘贴依赖,在这两个项目内的application.yaml粘贴配置。并且我在控制台也已经手动创建simple.queue队列。

在这里插入图片描述
在这里插入图片描述

接收消息:
随便创建个类写如下代码

@Component
public class SpringRabbitListener {// 利用RabbitListener来声明要监听的队列信息// 将来一旦监听的队列中有了消息,就会推送给当前服务,调用当前方法,处理消息。// 可以看到方法体中接收的就是消息体的内容@RabbitListener(queues = "simple.queue")//队列名public void listenSimpleQueueMessage(String msg) throws InterruptedException {System.out.println("spring 消费者接收到消息:【" + msg + "】");}
}

发送消息:
在publisher项目的测试类里写如下代码

@SpringBootTest
public class SpringAmqpTest {@Resourceprivate RabbitTemplate rabbitTemplate;@Testpublic void testSimpleQueue() {// 队列名称String queueName = "simple.queue";// 消息String message = "hello, spring amqp!";// 发送消息rabbitTemplate.convertAndSend(queueName, message);}
}

先运行consumer项目的启动类,再运行测试类发送信息,就可以看到在consumer项目控制台接收信息了。


总结

以上就是简单的消息收发,具体的编程化创建虚拟机,队列以及收发信息,我会在讲解交换机的文章中讲解。

相关文章:

  • RabbitMQ 的网页界面操作说明
  • Linux-Ubuntu环境下搭建SVN服务器
  • 【开源】基于Vue.js的民宿预定管理系统
  • python web项目导包规范
  • 【ES6.0】- Promise对象
  • idea git将某个分支内的commit合并到其他分支
  • 动态规划学习——子序列问题
  • python之UDP网络应用程序开发
  • selinux-policy-default(2:2.20231119-2)软件包内容详细介绍(2)
  • ⑧【HyperLoglog】Redis数据类型:HyperLoglog [使用手册]
  • 搜索引擎---项目测试
  • 如何取消thunar为默认文件管理器
  • MySQL索引 Error1071
  • 基于单片机的温湿度检测系统设计
  • 遥遥领先!TinyEngine 低代码引擎更新升级!AI 已成功部署!
  • [译] React v16.8: 含有Hooks的版本
  • 2017年终总结、随想
  • Consul Config 使用Git做版本控制的实现
  • django开发-定时任务的使用
  • E-HPC支持多队列管理和自动伸缩
  • Java小白进阶笔记(3)-初级面向对象
  • leetcode388. Longest Absolute File Path
  • vue-cli3搭建项目
  • 阿里云Kubernetes容器服务上体验Knative
  • 百度小程序遇到的问题
  • 技术攻略】php设计模式(一):简介及创建型模式
  • 解决iview多表头动态更改列元素发生的错误
  • 坑!为什么View.startAnimation不起作用?
  • 聊聊sentinel的DegradeSlot
  • 模型微调
  • 前端学习笔记之观察者模式
  • 用 Swift 编写面向协议的视图
  • CMake 入门1/5:基于阿里云 ECS搭建体验环境
  • ​ 轻量应用服务器:亚马逊云科技打造全球领先的云计算解决方案
  • # 手柄编程_北通阿修罗3动手评:一款兼具功能、操控性的电竞手柄
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (附源码)ssm教师工作量核算统计系统 毕业设计 162307
  • (十二)python网络爬虫(理论+实战)——实战:使用BeautfulSoup解析baidu热搜新闻数据
  • (循环依赖问题)学习spring的第九天
  • (转)程序员疫苗:代码注入
  • (转载)Linux 多线程条件变量同步
  • ***详解账号泄露:全球约1亿用户已泄露
  • @serverendpoint注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • [20170705]diff比较执行结果的内容.txt
  • [2019.2.28]BZOJ4033 [HAOI2015]树上染色
  • [Android] Implementation vs API dependency
  • [AR Foundation] 人脸检测的流程
  • [Effective C++读书笔记]0012_复制对象时勿忘其每一部分
  • [Grafana]ES数据源Alert告警发送
  • [leetcode]_String to Integer (atoi)
  • [leetcode]114. Flatten Binary Tree to Linked List由二叉树构建链表
  • [LeetCode]-225. 用队列实现栈
  • [LeetCode]—Copy List with Random Pointer 深度复制带“任意指针”的链表
  • [Linux]进程间通信(system V共享内存 | system V信号量)