RabbitMQ-Topic(主题模式)

news2025/1/11 12:42:27

Topic

topics 模式支持模糊匹配RoutingKey,就像是sql中的 like子句模糊查询,而路由模式等同于sql中的where子句等值查询

topic 交换机背后的路由算法类似于 direct 交换,使用特定路由键发送的消息将被传递到使用匹配绑定键绑定的所有队列。

 

如上图,主题模式不能具有任意的 routingKey,必须由一个英文句点“.”分隔的字符串(分割符),比如 “ fruit.orange.mango ”。

交换机和队列的Binding key用通配符来表示,有两种语法:

  • 星号* 表示至少,且只能占位一个单词。代表进入该队列的消息,指定的routingKey只能是3个单词组成,单词与单词之间用 * 间隔符,且中间的单词是product
  • # 可以替代 0 或多个单词;

例如 #.com.#
#可以表示0级或多级。xx.com、com.xx、com、xx.com.xx.xx、xx.xx.com.xx都可以

例如 *.com. *
*表示一级,xx.com.xx 可以 ,com.xx 不可以,前面缺少一级,xx.com.xx.xx不可以,com后面只能有一级xx,最终格式必须是 xx.com.xx

=============================创建Topic主题===============================

public void createTopic() {
    //交换机
    String exchangeName = "EW_EXCHANGE";
    //队列
    String queueProductName = "EW_PRODUCT";
    //key
    String routKeyProduct = "*.product.*";
    //队列
    String queueDeviceName = "EW_DEVICE";
    //key
   //key= *.*.device,消息投递指定的routingKey只能是3个单词组成,且最后一个单词为rabbit
    String routKeyDevice = "*.*.device";
//key= #.device2,由于#号表示,占位0个或多个,也就是说,不管routingKey是 device2还是 xx.xx.device2都是符合的,但是device2单词后面不能再有单词,比如 device2.xx...
    String routKeyDevice2 = "#.device2";

/**
 * 交换机
 * 第一个参数为队列名字,
 * 第二个参数为是否持久化,
 * 第三个参数为不使用队列时自动删除
 */
    
    TopicExchange exchange = new TopicExchange(exchangeName, true, false);
    amqpAdmin.declareExchange(exchange);
/**
 *队列
 * 第一个参数为队列名字,
 * 第二个参数为是否持久化,
 * 第三个参数为是否排他(true:一个连接只能有一个队列,false:一个连接可以有多个(推荐))
 * 第四个参数为不使用队列时自动删除
 */
    //产品
    Queue queue = new Queue(queueProductName, true, false, false);
    amqpAdmin.declareQueue(queue);
    //设备队列
    Queue queueDevice = new Queue(queueDeviceName, true, false, false);
    amqpAdmin.declareQueue(queueDevice);
    //交换机与设备绑定
    //一个队列可以绑定多个 key值
/**
 * 第一个参数为目的地,就是交换机或者队列的名字
 * 第二个参数为目的地类型,交换机还是队列
 * 第三个参数为交换机,QUEUE-队列  EXCHANGE-交换机
 * 第四个参数为路由键,匹配的名称
 */
    Binding bindingProduct = new Binding(queueProductName, Binding.DestinationType.QUEUE, exchangeName, routKeyProduct, null);
    amqpAdmin.declareBinding(bindingProduct);
    Binding bindingDevice = new Binding(queueDeviceName, Binding.DestinationType.QUEUE, exchangeName, routKeyDevice, null);
    amqpAdmin.declareBinding(bindingDevice);
 Binding bindingDevice2 = new Binding(queueDeviceName, Binding.DestinationType.QUEUE,         exchangeName, routKeyDevice, null); amqpAdmin.declareBinding(bindingDevice2 );
}

=======================发送消息========================

String msg="好了么";
Message message = MessageBuilder.withBody(msg.getByte())
    .setContentType(MessageProperties.CONTENT_TYPE_JSON)
    .setContentEncoding("UTF-8")
    .setMessageId(UUID.randomUUID().toString()).build();

rabbitTemplate.convertAndSend(exchangeName, routKeyProduct, message, new CorrelationData(UUID.randomUUID().toString()));

============================yml==============================

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/456491.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

期权价格上下限与期权平价关系

目录 1. 期权的基本概念 2. 期权的上下限 3. 期权的平价关系 1. 期权的基本概念 期权:是一种选择权,期权买方向卖方支付一定数额的 期权费 后,可获得在 一定时间(到期日)内以 一定价格(执行价格&#x…

如何使用 Java 将 JSON 文件读取为字符串?这三种方法很管用!

JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式,它可以用来存储和传输结构化的数据。在 Java 中,有多种方法可以将 JSON 文件读取为字符串,本文将介绍其中的几种。 方法一:使用 java.io 包中的类 java.io 包中提…

【MySQL】索引和事务的详细介绍

目录 一.索引 1.索引概念 2.查看索引 3.创建索引 4.索引使用的数据结构是什么 1.HASH(不是) 2.二叉搜索树(不是) 3.B树 N叉数(不是) 4.B树(是滴) 5.组合索引 6.索引覆盖 7…

Docker Compose与Docker Swarm的简介和区别,以及docker swarm的简单使用命令

Docker Compose与Docker Swarm的简介和区别 背景Compose 简介Swarm 简介Compose 和 Swarm区别docker swarm简单使用及常用命令背景:初始化集群节点加入启动docker程序,nginx服务1.22版本查看服务服务伸缩删除service服务创建密钥secret查看secret使用sec…

清徐乡村e镇助力醋企惊艳亮相全国糖酒会

陈醋香醇悠悠,美味酸爽袭人。4月12日至14日,第108届全国糖酒商品交易会在成都举行,其间启动“山西老陈醋专业镇成都行”,208家山西醋企首次集中亮相交易会,为山西醋代言,由阿里云创新中心运营的清徐乡村e镇…

操作系统概述和体系结构

操作系统的概念和功能 核心:作为系统资源的管理者 向上提供方便易用的服务 联机就好比问一句答一句;脱机就好比先问好多句然后统一依次回答。 上面是直接提供给用户使用的。 另外还有一种程序接口: 这就是程序员在编程时经常调用的各种函数接…

【Linux】3、Linux 的编辑器

目录 一、vi 和 vim二、vim(vi)的三种工作模式(1) 命令模式快捷键(2) 底线命令模式操作 一、vi 和 vim 🔖 vim 和 vi 是 Linux 中经典的文本编辑器 🔖 vim 是 vi 的加强版 🔖 vim: ① 兼容 vi 的全部指令…

(数字图像处理MATLAB+Python)第五章图像增强-第六节:其他图像增强技术

文章目录 一:基于对数图像处理模型的图像增强(1)对数图像处理模型(LIP)(2)基于对数图像处理模型的增强 二:图像去雾增强(1)图像去雾模型(2&#x…

Flutter 布局探索 | 如何分析尺寸和约束

theme: cyanosis 前言 本文来分享一下,通过查看源码和布局信息解决的一个实际中的布局小问题,也希望通过本文的分享,当你遇到布局问题时,可以靠自己的脑子和双手解决问题。 如下所示,将 TextField 作为 AppBar 组件的 …

java版本工程项目管理系统平台源码,助力工程企业实现数字化管理

鸿鹄工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离构建工程项目管理系统 1. 项目背景 一、随着公司的快速发展,企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性,公司对内部工程管…

重塑元宇宙体验!元宇宙实时云渲染解决方案来了

元宇宙作为人工智能、云计算和数字孪生等前沿技术的结合体,近年来越发受到各大企业重视。 元宇宙的应用场景层出不穷,不仅包括营销推广场景,还有品牌活动和电商销售,能有效提升品宣和商业转化效果。 元宇宙也具有极大的建设价值…

2.Spring Security详细使用

目录 1. Spring Security详细介绍 2. Spring Security详细使用 3. Spring Security实现JWT token验证 4. JWT(JSON Web Token,JSON令牌) 5. Spring Security安全注解 认证流程 1.集中式认证流程 (1)用户认证 使用…

【Unity入门】15.鼠标输入和键盘输入

【Unity入门】鼠标输入和键盘输入 大家好,我是Lampard~~ 欢迎来到Unity入门系列博客,所学知识来自B站阿发老师~感谢 (一)监听鼠标输入 (1) Input类 Unity的Input类提供了许多监听用户输入的方法,比如我们常见的鼠标&a…

redis复制的设计与实现

一、复制 1.1旧版功能的实现 旧版Redis的复制功能分为 同步(sync)和 命令传播。 同步用于将从服务器更新至主服务器的当前状态。命令传播用于 主服务器状态变化时,让主从服务器状态回归一致。 1.1.1同步 当客户端向服务端发送slaveof命令…

5款十分小众的软件,知道的人不多但却很好用

今天推荐5款十分小众的软件,知道的人不多,但是每个都是非常非常好用的,有兴趣的小伙伴可以自行搜索下载。 1.视频直播录制——OBS Studio OBS Studio可以让你轻松地录制和直播你的屏幕、摄像头、游戏等内容。你可以使用OBS Studio来创建多种…

opengl入门之创建窗口

OpenGL系列文章目录 文章目录 OpenGL系列文章目录前言GLFWGLFW Logo构建GLFWAttention编译生成的库CMake编译我们的第一个工程链接Windows上的OpenGL库Linux上的OpenGL库ImportantGLAD配置GLAD 附加资源 前言 注意,由于作者对教程做出了更新,之前本节使…

springboot使用jasper实现报表demo

概述 业务中尝尝需要用到报表数据的渲染和导出.报表的配置势必不能写死,需要动态配置。 现成的JasperReports Jaspersoft Studio即可实现可配置的报表。 报表布局Jaspersoft Studio https://community.jaspersoft.com/community-download 下载布局工具&#xf…

【fisco-bcos底层链】WeBASE管理平台各组件分别打包成镜像部署到k8s上亲测完成

【fisco-bcos底层链】WeBASE管理平台各组件分别打包成镜像部署到k8s上亲测完成 前言第一步、docker 打包dockerfile书写第二步、fisco-bcos 三节点的底层链1. 更改数据库连接信息2.删除节点中运行预语句中最后的的&符号3. 具体编译的dockerfile4. 编译dockerfile生成 fisco…

【Linux编程Shell自动化脚本】01 Shell 变量、条件语句及常用概念操作等详解

文章目录 一、简介二、变量详解1. 系统变量 三、If条件语句1. ()、(())、[]、[[]]、let和test的区别(1)bash中的Compound Commands(2)Shell Builtin Commands(3)Arithmetic Evaluation(4&#x…

【MySQL | 进阶篇】09、MySQL 管理及常用工具(mysqladmin、mysqlbinlog、mysqldump 等)的使用

目录 一、系统数据库 二、常用工具 2.1 mysql 示例 2.2 mysqladmin 示例 2.3 mysqlbinlog 示例 2.4 mysqlshow 示例 2.5 mysqldump(数据备份) 示例 2.6 mysqlimport/source(数据恢复) 2.6.1 mysqlimport 2.6.2 …