当前位置:首页 > 科技  > 软件

SpringBoot整合RabbitMQ四种交换机类型详解

来源: 责编: 时间:2023-08-14 22:01:41 481观看
导读环境:Spring Boot2.3.10 + RabbitMQ 3.8.12 + Erlang 23.2.51.1 RabbitMQ介绍RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的。所有主要的编程语

环境:Spring Boot2.3.10 + RabbitMQ 3.8.12 + Erlang 23.2.5rXL28资讯网——每日最新资讯28at.com

1.1 RabbitMQ介绍

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的。所有主要的编程语言均有与代理接口通讯的客户端库。rXL28资讯网——每日最新资讯28at.com

1.2 RabbitMQ核心概念

Server:又称Broker, 接受客户端的连接,实现AMQP实体服务,这里指RabbitMQ 服务器rXL28资讯网——每日最新资讯28at.com

Connection:连接,应用程序与Broker的网络连接。rXL28资讯网——每日最新资讯28at.com

Channel:通信通道,几乎所有的操作都在 Channel 中进行,Channel是进行消息读写的通道。客户端可建立多个Channel:,每个Channel代表一个会话任务。(一个Socket连接可以创建多个Channel)rXL28资讯网——每日最新资讯28at.com

Virtual Host:虚拟主机,用于逻辑隔离,是最上层的消息路由。一个 Virtual Host 里面可以有若干个 Exchange(交换机)和 Queue(队列)。rXL28资讯网——每日最新资讯28at.com

Binding:Exchange 和 Queue 之间的虚拟绑定关系。rXL28资讯网——每日最新资讯28at.com

Routing key:一 个路由规则,虚拟机可用它来确定如何路由一个特定消息,即交换机绑定到 Queue 的键。支持模式匹配,* 和#,*用来匹配一个单词,#用来匹配多个单词(可以是0个)这里的通配符只有在exchange的类型为topic才有效。rXL28资讯网——每日最新资讯28at.com

Queue:也称为Message Queue,消息队列,保存消息并将它们转发给消费者。(接收端通过监听Queue来接受消息)。rXL28资讯网——每日最新资讯28at.com

Message:消息,服务器和应用程序之间传送的数据,由 Properties 和 Body 组成。Properties 可以对消息进行修饰,比如消息的优先级、延迟,过期时间,消息大小等高级特性;,Body 则就 是消息体内容。rXL28资讯网——每日最新资讯28at.com

Exchange类型:如下四种类型:fanout,headers,direct,topic。rXL28资讯网——每日最新资讯28at.com

图片图片rXL28资讯网——每日最新资讯28at.com

rXL28资讯网——每日最新资讯28at.com

  • 新建队列:fanout-queue1,fanout-queue2,fanout-queue3

图片图片rXL28资讯网——每日最新资讯28at.com

rXL28资讯网——每日最新资讯28at.com

按照上面的方式分别建立3个队列。rXL28资讯网——每日最新资讯28at.com

  • 将fanout-exchange与3个队列(fanout-queue*)进行绑定

图片图片rXL28资讯网——每日最新资讯28at.com

将3个队列分别于fanout-exchange进行绑定,这里在绑定时分别设定了不同的路由key,就是为了验证fanout类型的交换机是否与routing key有关系。rXL28资讯网——每日最新资讯28at.com

  • 测试

发送接口:rXL28资讯网——每日最新资讯28at.com

@RestController@RequestMapping("/messages")public class MessageController {  @Resource  private MessageSend ms ;  @GetMapping("/sendFanout")  public Object send(String msg) {    ms.send(msg) ;    return "success" ;}}@Resourceprivate RabbitTemplate rabbitTemplate ;public void send(String msg) {  logger.info("准备发送消息:{}", msg);  rabbitTemplate.convertAndSend("fanout-exchange", "rk.1.2", msg) ;}

这里故意设置了路由key 就是为了看fanout类型的交换机是否与routing key 有关系。rXL28资讯网——每日最新资讯28at.com

图片图片rXL28资讯网——每日最新资讯28at.com

3个队列都收到了消息,说明fanout类型的交换机与绑定queue时routing key是没有关系的,只要绑定了该类型的交换机都会收到消息。rXL28资讯网——每日最新资讯28at.com

2、headers类型交换机rXL28资讯网——每日最新资讯28at.com

  • 通过RabbitMQ控制台新建headers类型交换机:headers-exchange

图片图片rXL28资讯网——每日最新资讯28at.com

  • 新建队列:headers-queue1,headers-queue2

图片图片rXL28资讯网——每日最新资讯28at.com

  • 将headers-exchange与2个队列(headers-queue*)进行绑定

图片图片rXL28资讯网——每日最新资讯28at.com

  • 测试

发送接口rXL28资讯网——每日最新资讯28at.com

@GetMapping("/sendHeaders")public Object sendHeaders(String msg) {  ms.sendHeaders(msg) ;  return "success" ;}public void sendHeaders(String msg) {  logger.info("准备发送消息:{}", msg);  Message message = MessageBuilder.withBody(msg.getBytes()).setHeader("a", "b").setHeader("pack", "xg").build() ;  rabbitTemplate.send("headers-exchange", "rk.1.2", message) ;}

注意:这里设置了Header信息与headers-exchange和headers-queue1绑定时设置的参数完全相同。rXL28资讯网——每日最新资讯28at.com

图片图片rXL28资讯网——每日最新资讯28at.com

headers-queue2就没有收到消息。如果在进行绑定时没有设置x-match参数默认是完全要匹配绑定时设定的参数,也就是x-match:all。如下,如果不配置x-match也就相当于:rXL28资讯网——每日最新资讯28at.com

图片图片rXL28资讯网——每日最新资讯28at.com

两个队列都收到了消息。rXL28资讯网——每日最新资讯28at.com

3、direct类型交换机rXL28资讯网——每日最新资讯28at.com

  • 通过RabbitMQ控制台新建direct类型交换机:direct-exchange

图片图片rXL28资讯网——每日最新资讯28at.com

  • 新建队列:direct-queue1,direct-queue2

图片图片rXL28资讯网——每日最新资讯28at.com

  • 将direct-exchange与2个队列(direct-queue*)进行绑定

图片rXL28资讯网——每日最新资讯28at.com

2个队列都收到了消息。rXL28资讯网——每日最新资讯28at.com

4、topic类型交换机rXL28资讯网——每日最新资讯28at.com

  • 通过RabbitMQ控制台新建topic类型交换机:topic-exchange

图片图片rXL28资讯网——每日最新资讯28at.com

  • 新建队列:topic-queue1,topic-queue2

图片图片rXL28资讯网——每日最新资讯28at.com

  • 将topic-exchange与2个队列(topic-queue*)进行绑定

图片图片rXL28资讯网——每日最新资讯28at.com

两个队列都收到了消息。rXL28资讯网——每日最新资讯28at.com

修改发送消息的routing keyrXL28资讯网——每日最新资讯28at.com

rabbitTemplate.convertAndSend("topic-exchange", "te.2.ok", msg) ;

图片图片rXL28资讯网——每日最新资讯28at.com

只有topic-queue2收到了消息,因为绑定时设置的routing-key 是:rXL28资讯网——每日最新资讯28at.com

图片图片rXL28资讯网——每日最新资讯28at.com

能够匹配多个单词。rXL28资讯网——每日最新资讯28at.com

以上就介绍完了rabbitmq的四种交换机类型。rXL28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-5752-0.htmlSpringBoot整合RabbitMQ四种交换机类型详解

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 谷歌全栈多平台应用开发神器Project IDX来了!PaLM 2加持,代码效率翻倍

下一篇: 前端请求大比拼:Fetch、Axios、Ajax、XHR

标签:
  • 热门焦点
  • Redmi Buds 4开箱简评:才199还有降噪 可以无脑入

    在上个月举办的Redmi Note11T Pro系列新机发布会上,除了两款手机新品之外,Redmi还带来了两款TWS真无线蓝牙耳机产品,Redmi Buds 4和Redmi Buds 4 Pro,此前我们在Redmi Note11T
  • 5月iOS设备好评榜:iPhone 14仅排第43?

    来到新的一月,安兔兔的各个榜单又重新汇总了数据,像安卓阵营的榜单都有着比较大的变动,不过iOS由于设备的更新换代并没有那么快,所以相对来说变化并不大,特别是iOS好评榜,老款设
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 得物效率前端微应用推进过程与思考

    一、背景效率工程随着业务的发展,组织规模的扩大,越来越多的企业开始意识到协作效率对于企业团队的重要性,甚至是决定其在某个行业竞争中突围的关键,是企业长久生存的根本。得物
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • 腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之“想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!”曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 自律,给不了Keep自由!

    来源 | 互联网品牌官作者 | 李大为编排 | 又耳 审核 | 谷晓辉自律能不能给用户自由暂时不好说,但大概率不能给Keep自由。近日,全球最大的在线健身平台Keep正式登陆港交所,努力
  • 认真聊聊东方甄选:如何告别低垂的果实

    来源:山核桃作者:财经无忌爆火一年后,俞敏洪和他的东方甄选依旧是颇受外界关心的“网红”。7月5日至9日,为期5天的东方甄选“甘肃行”首次在自有App内直播,
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
Top