您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

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

时间:2021-04-22 10:14:42  来源:今日头条  作者:FastCoder
环境:Spring Boot2.3.10 + RabbitMQ 3.8.12 + Erlang 23.2.5

1.1 RabbitMQ介绍

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

1.2 RabbitMQ核心概念

Server:又称Broker, 接受客户端的连接,实现AMQP实体服务,这里指RabbitMQ 服务器
Connection:连接,应用程序与Broker的网络连接。
Channel:通信通道,几乎所有的操作都在 Channel 中进行,Channel是进行消息读写的通道。客户端可建立多个Channel:,每个Channel代表一个会话任务。(一个Socket连接可以创建多个Channel)
Virtual Host:虚拟主机,用于逻辑隔离,是最上层的消息路由。一个 Virtual Host 里面可以有若干个 Exchange(交换机)和 Queue(队列)。
Binding:Exchange 和 Queue 之间的虚拟绑定关系。
Routing key:一 个路由规则,虚拟机可用它来确定如何路由一个特定消息,即交换机绑定到 Queue 的键。支持模式匹配,* 和#,*用来匹配一个单词,#用来匹配多个单词(可以是0个)这里的通配符只有在exchange的类型为topic才有效。
Queue:也称为Message Queue,消息队列,保存消息并将它们转发给消费者。(接收端通过监听Queue来接受消息)。
Message:消息,服务器和应用程序之间传送的数据,由 Properties 和 Body 组成。Properties 可以对消息进行修饰,比如消息的优先级、延迟,过期时间,消息大小等高级特性;,Body 则就 是消息体内容。
Exchange类型:如下四种类型:fanout,headers,direct,topic。
SpringBoot整合RabbitMQ四种交换机类型详解

1.3 Exchange交换机类型

1、 fanout
发布/订阅,消费发送到该种类型的交换机后会将消息发送到所有与之绑定的Queue中,不管你有没有设置routing key。
2、 headers
该类型用得极少,主要就是根据设置的header来进行匹配。如下红框中你所设置的
arguments:
SpringBoot整合RabbitMQ四种交换机类型详解
3、 direct
在exchange与queue进行绑定时需要设置routing key,只有发送消息的端设置的routing key与这里绑定的routingkey完全相同才会将消息发到队列中。
4、 topic

exchange与queue绑定时设置的routing key支持通配符*和#,*用来匹配一个单词,#用来匹配多个单词(可以是0个)。

1.4 使用案例

准备环境:
依赖
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
配置文件
spring:
  rabbitmq:
    host: localhost
    port: 5672
    username: admin
    password: 123456
    virtual-host: /
    publisherConfirmType: correlated
    publisherReturns: true
    listener:
      simple:
        concurrency: 5
        maxConcurrency: 10
        prefetch: 5
        acknowledgeMode: MANUAL
        retry:
          enabled: true
          initialInterval: 3000
          maxAttempts: 3
        defaultRequeueRejected: false
1、fanout类型交换机
  • 通过RabbitMQ控制台新建fanout类型交换机:fanout-exchange
SpringBoot整合RabbitMQ四种交换机类型详解
  • 新建队列:fanout-queue1,fanout-queue2,fanout-queue3
SpringBoot整合RabbitMQ四种交换机类型详解
按照上面的方式分别建立3个队列。
  • 将fanout-exchange与3个队列(fanout-queue*)进行绑定
SpringBoot整合RabbitMQ四种交换机类型详解
将3个队列分别于fanout-exchange进行绑定,这里在绑定时分别设定了不同的路由key,就是为了验证fanout类型的交换机是否与routing key有关系。
  • 测试
发送接口:
@RestController
@RequestMApping("/messages")
public class MessageController {
  @Resource
  private MessageSend ms ;
  @GetMapping("/sendFanout")
  public Object send(String msg) {
    ms.send(msg) ;
    return "success" ;
	}
}
@Resource
private RabbitTemplate rabbitTemplate ;
	
public void send(String msg) {
  logger.info("准备发送消息:{}", msg);
  rabbitTemplate.convertAndSend("fanout-exchange", "rk.1.2", msg) ;
}
这里故意设置了路由key 就是为了看fanout类型的交换机是否与routing key 有关系。
SpringBoot整合RabbitMQ四种交换机类型详解
3个队列都收到了消息,说明fanout类型的交换机与绑定queue时routing key是没有关系的,只要绑定了该类型的交换机都会收到消息。
2、headers类型交换机
  • 通过RabbitMQ控制台新建headers类型交换机:headers-exchange
SpringBoot整合RabbitMQ四种交换机类型详解
  • 新建队列:headers-queue1,headers-queue2
SpringBoot整合RabbitMQ四种交换机类型详解
  • 将headers-exchange与2个队列(headers-queue*)进行绑定
SpringBoot整合RabbitMQ四种交换机类型详解
  • 测试
发送接口
@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绑定时设置的参数完全相同。
SpringBoot整合RabbitMQ四种交换机类型详解
headers-queue2就没有收到消息。如果在进行绑定时没有设置x-match参数默认是完全要匹配绑定时设定的参数,也就是x-match:all。如下,如果不配置x-match也就相当于:
SpringBoot整合RabbitMQ四种交换机类型详解
x-match 还有一个取值就是any,只要有任意的一个匹配上那就成功。
修改headers-queue1,headers-queue2绑定的参数,如下:
SpringBoot整合RabbitMQ四种交换机类型详解
两个参数中都加入了x-match:any 只要有任意一个参数匹配即可。
再次发送消息:
SpringBoot整合RabbitMQ四种交换机类型详解
两个队列都收到了消息。
3、direct类型交换机
  • 通过RabbitMQ控制台新建direct类型交换机:direct-exchange
SpringBoot整合RabbitMQ四种交换机类型详解
  • 新建队列:direct-queue1,direct-queue2
SpringBoot整合RabbitMQ四种交换机类型详解
  • 将direct-exchange与2个队列(direct-queue*)进行绑定
SpringBoot整合RabbitMQ四种交换机类型详解
  • 测试
发送接口:
@GetMapping("/sendDirect")
public Object sendDirect(String msg) {
  ms.sendDirect(msg) ;
  return "success" ;
}
public void sendDirect(String msg) {
  logger.info("准备发送消息:{}", msg);
  rabbitTemplate.convertAndSend("direct-exchange", "de.m", msg) ;
}
SpringBoot整合RabbitMQ四种交换机类型详解
2个队列都收到了消息。
4、topic类型交换机
  • 通过RabbitMQ控制台新建topic类型交换机:topic-exchange
SpringBoot整合RabbitMQ四种交换机类型详解
  • 新建队列:topic-queue1,topic-queue2
SpringBoot整合RabbitMQ四种交换机类型详解
  • 将topic-exchange与2个队列(topic-queue*)进行绑定
SpringBoot整合RabbitMQ四种交换机类型详解
*: 只能匹配一个单词;#:能匹配多个单词(也可以是0个)。
  • 测试
发送接口:
@GetMapping("/sendTopic")
public Object sendTopic(String msg) {
  ms.sendTopic(msg) ;
  return "success" ;
}
public void sendTopic(String msg) {
  logger.info("准备发送消息:{}", msg);
  rabbitTemplate.convertAndSend("topic-exchange", "te.1.ok", msg) ;
}
SpringBoot整合RabbitMQ四种交换机类型详解
两个队列都收到了消息。
修改发送消息的routing key
rabbitTemplate.convertAndSend("topic-exchange", "te.2.ok", msg) ;
SpringBoot整合RabbitMQ四种交换机类型详解
只有topic-queue2收到了消息,因为绑定时设置的routing-key 是:
SpringBoot整合RabbitMQ四种交换机类型详解
能够匹配多个单词。
以上就介绍完了rabbitmq的四种交换机类型。
完毕!!!
 


Tags:SpringBoot   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
我是一名程序员关注我们吧,我们会多多分享技术和资源。进来的朋友,可以多了解下青锋的产品,已开源多个产品的架构版本。Thymeleaf版(开源)1、采用技术: springboot、layui、Thymel...【详细内容】
2021-12-14  Tags: SpringBoot  点击:(20)  评论:(0)  加入收藏
前言项目中的配置文件会有密码的存在,例如数据库的密码、邮箱的密码、FTP的密码等。配置的密码以明文的方式暴露,并不是一种安全的方式,特别是大型项目的生产环境中,因为配置文...【详细内容】
2021-11-17  Tags: SpringBoot  点击:(25)  评论:(0)  加入收藏
SpringBoot开发的物联网通信平台系统项目功能模块 功能 说明 MQTT 1.SSL支持 2.集群化部署时暂不支持retain&will类型消 UDP ...【详细内容】
2021-11-05  Tags: SpringBoot  点击:(55)  评论:(0)  加入收藏
1. 介绍1.1 介绍今天开始我们来学习Java操作MySQL数据库的技巧,Java操作MySQL是借助JdbcTemplate这个对象来实现的。JdbcTemplate是一个多数据库集中解决方案,而我们今天只讲...【详细内容】
2021-11-05  Tags: SpringBoot  点击:(30)  评论:(0)  加入收藏
SpringBoot中的Controller注册本篇将会以Servlet为切入点,通过源码来看web容器中的Controller是如何注册到HandlerMapping中。请求来了之后,web容器是如何根据请求路径找到对...【详细内容】
2021-11-04  Tags: SpringBoot  点击:(52)  评论:(0)  加入收藏
环境:Springboot2.4.11环境配置接下来的演示都是基于如下接口进行。@RestController@RequestMapping("/exceptions")public class ExceptionsController { @GetMapping(...【详细内容】
2021-10-11  Tags: SpringBoot  点击:(41)  评论:(0)  加入收藏
SpringBoot项目默认使用logback, 已经内置了 logback 的相关jar包,会从resource包下查找logback.xml, logback 文件格式范本 可直接复制使用,有控制台 info.log error.log三个...【详细内容】
2021-10-09  Tags: SpringBoot  点击:(50)  评论:(0)  加入收藏
环境:Springboot2.4.10当应用程序启动时,Spring Boot将自动从以下位置查找并加载application.properties和application.yaml文件: 从Classpath类路径classpath的根类路径classp...【详细内容】
2021-09-26  Tags: SpringBoot  点击:(76)  评论:(0)  加入收藏
搭建基础1. Intellij IDEA 2. jdk1.8 3. maven3.6.3搭建方式(1)在线创建项目Spring Boot 官方提供的一种创建方式,在浏览器中访问如下网址: https://start.spring.io/在打开的页...【详细内容】
2021-09-14  Tags: SpringBoot  点击:(78)  评论:(0)  加入收藏
最近开发项目的时候需要用到对象的属性拷贝,以前也有用过一些复制框架,比如spring的 BeanUtils.copyProperties等方式,但总是不尽如人意,最近发现使用orika进行对象拷贝挺好用的...【详细内容】
2021-08-27  Tags: SpringBoot  点击:(231)  评论:(0)  加入收藏
▌简易百科推荐
近日只是为了想尽办法为 Flask 实现 Swagger UI 文档功能,基本上要让 Flask 配合 Flasgger, 所以写了篇 Flask 应用集成 Swagger UI 。然而不断的 Google 过程中偶然间发现了...【详细内容】
2021-12-23  Python阿杰    Tags:FastAPI   点击:(6)  评论:(0)  加入收藏
文章目录1、Quartz1.1 引入依赖<dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.2</version></dependency>...【详细内容】
2021-12-22  java老人头    Tags:框架   点击:(11)  评论:(0)  加入收藏
今天来梳理下 Spring 的整体脉络啦,为后面的文章做个铺垫~后面几篇文章应该会讲讲这些内容啦 Spring AOP 插件 (了好久都忘了 ) 分享下 4ye 在项目中利用 AOP + MybatisPlus 对...【详细内容】
2021-12-07  Java4ye    Tags:Spring   点击:(14)  评论:(0)  加入收藏
&emsp;前面通过入门案例介绍,我们发现在SpringSecurity中如果我们没有使用自定义的登录界面,那么SpringSecurity会给我们提供一个系统登录界面。但真实项目中我们一般都会使用...【详细内容】
2021-12-06  波哥带你学Java    Tags:SpringSecurity   点击:(18)  评论:(0)  加入收藏
React 简介 React 基本使用<div id="test"></div><script type="text/javascript" src="../js/react.development.js"></script><script type="text/javascript" src="../js...【详细内容】
2021-11-30  清闲的帆船先生    Tags:框架   点击:(19)  评论:(0)  加入收藏
流水线(Pipeline)是把一个重复的过程分解为若干个子过程,使每个子过程与其他子过程并行进行的技术。本文主要介绍了诞生于云原生时代的流水线框架 Argo。 什么是流水线?在计算机...【详细内容】
2021-11-30  叼着猫的鱼    Tags:框架   点击:(21)  评论:(0)  加入收藏
TKinterThinter 是标准的python包,你可以在linx,macos,windows上使用它,你不需要安装它,因为它是python自带的扩展包。 它采用TCL的控制接口,你可以非常方便地写出图形界面,如...【详细内容】
2021-11-30    梦回故里归来  Tags:框架   点击:(26)  评论:(0)  加入收藏
前言项目中的配置文件会有密码的存在,例如数据库的密码、邮箱的密码、FTP的密码等。配置的密码以明文的方式暴露,并不是一种安全的方式,特别是大型项目的生产环境中,因为配置文...【详细内容】
2021-11-17  充满元气的java爱好者  博客园  Tags:SpringBoot   点击:(25)  评论:(0)  加入收藏
一、搭建环境1、创建数据库表和表结构create table account(id INT identity(1,1) primary key,name varchar(20),[money] DECIMAL2、创建maven的工程SSM,在pom.xml文件引入...【详细内容】
2021-11-11  AT小白在线中  搜狐号  Tags:开发框架   点击:(29)  评论:(0)  加入收藏
SpringBoot开发的物联网通信平台系统项目功能模块 功能 说明 MQTT 1.SSL支持 2.集群化部署时暂不支持retain&will类型消 UDP ...【详细内容】
2021-11-05  小程序建站    Tags:SpringBoot   点击:(55)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条