RabbitMQ 基础 学习笔记1

RabbitMQ架构

虚拟主机(vhost):一个"用户"只能操作属于自己的虚拟主机里的交换机和队列,起到了数据隔离的作用。

MQ(消息队列)技术对比

交换机

绝大多数情况下,消息传递过程是:生产者->交换机->队列->消费者

Fanout交换机

消费者(指定交换机 )->Fanout交换机->广播到所有(与Fanout绑定的)队列

Direct交换机和Topic交换机

消费者(指定交换机+bindingkey )->Direct交换机->定向到所有(与Direct交换机绑定+bindingkey匹配的)队列

消费者(指定交换机+bindingkey )->Topic交换机->定向到所有(与Topic交换机绑定+bindingkey匹配的)队列

对比一下Direct交换机和Topic交换机

消费者(指定交换机+bindingkey)->Direct交换机->定向到所有(与Direct交换机绑定+bindingkey匹配的)队列

消费者(指定交换机+bindingkey)->Topic交换机->定向到所有(与Topic交换机绑定+bindingkey匹配的)队列

是不是一摸一样?是的,那总该得有区别吧?区别在于:

Direct 交换机bindingkey完全精确匹配,无通配符支持

Topic 交换机bindingkey模糊匹配 ,支持两种通配符:1. *:匹配一个. 分隔的单词

  1. #:匹配零个或多个. 分隔的单词

声明交换机和队列

在控制台手动声明

RabbitMQ 的控制台官方名称是 RabbitMQ Management UI(也常简称为「RabbitMQ 管理控制台」「RabbitMQ 管理界面」),是 RabbitMQ 官方提供的可视化管理工具。

访问方式 :启动RabbitMQ服务后,默认通过浏览器访问 http://[RabbitMQ服务器IP]:15672(默认端口 15672),需输入 RabbitMQ 的用户名 / 密码(默认管理员账号:guest/guest,仅本地访问有效)。

在代码中自动化声明(以Java为例)

配置类中声明交换机、队列、绑定(Fanout无此):

注释声明:

在消费者方法上加上注释

消息转换器

生产者与消费者之间的交换机、队列里面装的消息是序列化后的信息,生产者要通过消息转换器把原始数据转换成交换机、队列之间的消息,消费者要通过消息转换器将接收到的消息转换成原始数据。

JDK序列化

JSON序列化

RabbitMQ进阶 学习笔记2:RabbitMQ 进阶 学习笔记2-CSDN博客

相关推荐
wrj的博客1 天前
python环境安装
python·学习·环境配置
优雅的潮叭1 天前
c++ 学习笔记之 chrono库
c++·笔记·学习
星火开发设计1 天前
C++ 数组:一维数组的定义、遍历与常见操作
java·开发语言·数据结构·c++·学习·数组·知识
星幻元宇VR1 天前
走进公共安全教育展厅|了解安全防范知识
学习·安全·虚拟现实
知识分享小能手1 天前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)
数据库·学习·oracle
不大姐姐AI智能体1 天前
搭了个小红书笔记自动生产线,一句话生成图文,一键发布,支持手机端、电脑端发布
人工智能·经验分享·笔记·矩阵·aigc
浅念-1 天前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
burning_maple1 天前
mysql数据库笔记
数据库·笔记·mysql
hkNaruto1 天前
【AI】AI学习笔记:LangGraph 与 LangChain的关系以及系统性学习路线选择
笔记·学习·langchain
jrlong1 天前
DataWhale大模型基础与量化微调task3学习笔记(第 5章:深入大模型架构_MoE 架构解析)
笔记·学习