美文网首页
【MQ】RabbitMQ 交换器与队列

【MQ】RabbitMQ 交换器与队列

作者: greedycr7 | 来源:发表于2020-10-17 20:56 被阅读0次

一、Exchange 交换器

1.1 Exchange Type

生产者将消息投递到交换器,然后交换器再将消息路由到一个或者多个队列中。
RabbitMQ 定义了4种类型的交换器:

  • fanout:将消息路由到与之绑定的所有队列中,这种交换器会无视 RoutingKey,类似于子网广播
  • direct:将消息路由到 RoutingKey 和 BindingKey 完全匹配的队列中
  • topic:将 RoutingKey 和 BindingKey 进行模式匹配,在 topic 模式下 RoutingKey 和 BindingKey 必须是用点号 "." 分隔的字符串,被点号 "." 分隔的每一段称为之单词。在 BindingKey 中,"*" 用来匹配一个单词,"#" 用来匹配零个或多个单词。
  • headers:不常用,略过

1.2 Exchange Declare

在使用交换器之前,需要先创建交换器,RabbitMQ 的 Java 客户端提供了 exchangeDeclare() 方法来声明交换器。

Exchange.DeclareOk exchangeDeclare(String exchangeName, String type, boolean durable, boolean autoDelete, boolean internal, Map<String, Object> arguments) throws IOException;

参数说明:

  • exchangeName:交换器的名称
  • type:交换器类型
  • durable:是否为持久化
  • autoDelete:是否自动删除
  • internal:是否为内部交换器
  • arguments:交换器的其它参数列表

返回值:

  • Exchange.DeclareOK:表示成功声明了一个交换器

方法重载:

Exchange.DeclareOk exchangeDeclare(String exchangeName, String type) throws IOException;

Exchange.DeclareOk exchangeDeclare(String exchangeName, String type, boolean durable) throws IOException;

Exchange.DeclareOk exchangeDeclare(String exchangeName, String type, boolean durable, boolean autoDelete, Map<String, Object> arguments) throws IOException;

1.3 Exchange Delete

有创建就会有删除,RabbitMQ 的 Java 客户端提供了 exchangeDelete() 方法来删除交换器。

Exchange.DeleteOk exchangeDelete(String exchangeName) throws IOException;

Exchange.DeleteOk exchangeDelete(String exchangeName, boolean isUnused) throws IOException;

参数说明:

  • exchangeName:交换器名称
  • isUnused:设置是否交换器处于未使用状态下才删除交换器;如果为 true,则只有在交换器处于未使用状态时才能被删除,如果为 false,则交换器会直接被删除

返回值:

  • Exchange.DeleteOk:表示成功删除了交换器

1.4 检测交换器是否存在

exchangeDeclarePassive() 方法用来检测交换器是否存在。如果存在,则正常返回;如果不存在,则抛出异常 404 channel exception

Exchange.DeclareOk exchangeDeclarePassive(String exchangeName) throws IOException;

二、Queue 队列

队列在 RabbitMQ 中用来存储消息,队列通过 BindingKey 与 交换器相互绑定。

2.1 Queue Declare

exchangeDeclare() 方法相比,queueDeclare() 的重载方法少很多,只有两个重载方法:

// 不带任何参数的 queueDeclare() 方法会创建一个匿名的、非持久化的、排它的、自动删除的队列
Queue.DeclareOk queueDeclare() throws IOException;

Queue.DeclareOk queueDeclare(String queueName, boolean durable, boolean exclusive, boolean autoDelete, Map<String, Object> arguments) throws IOException;

参数说明:

  • queueName:队列名称
  • durable:是否为持久化
  • exclusive:是否为排它的,如果一个队列为排它的,那么这个队列只能对首次声明它的连接可见,其它连接不允许建立同名的排它队列;如果队列是排它的,那么当连接断开时,不管队列是否是持久化的,都会被删除
  • autoDelete:是否自动删除
  • arguments:队列的其它参数列表

返回值:

  • Queue.DeclareOk:表示成功声明了一个队列

2.2 Queue Delete

与交换器一样,队列也可以删除

Queue.DeleteOk queueDelete(String queueName) throws IOException;

Queue.DeleteOk queueDelete(String queueName, boolean isUnused, boolean isEmpty) throws IOException;

参数说明:

  • queueName:队列名称
  • isUnused:是否在队列处于未使用状态时删除队列
  • isEmpty:是否在队列为空时删除队列

返回值:

  • Queue.DeleteOk:表示队列删除成功

2.3 检测队列是否存在

Queue.DeclareOk queueDeclarePassive(String queueName) throws IOException;

相关文章

  • 【MQ】RabbitMQ 交换器与队列

    一、Exchange 交换器 1.1 Exchange Type 生产者将消息投递到交换器,然后交换器再将消息路由...

  • RabbitMQ安装配置

    RabbitMQ 安装和配置 RabbitMQ 说明 MQ 全称为 Message Queue, 消息队列(MQ)...

  • RabbitMQ-理解消息通信-持久化策略

    重启RabbitMQ后,队列和交换器都会消失(随同里面的消息),原因在于每个队列和交换器的durable属性,该属...

  • SpringBoot+RabbitMQ

    RabbitMQ MQ - 消息队列(essage Queue)RabbitMQ是一个由erlang开发的AMQP...

  • RabbitMQ 研究

    1 、介绍 1.1 RabbitMQ MQ全称为Message Queue,即消息队列, RabbitMQ是由er...

  • RabbitMQ

    轻松搞定rabbitMQ到底什么时候使用MQ消息队列之 RabbitMQ MQ一共有三种路由器:广播,直接,主题。...

  • 二、RabbitMQ架构模型

    RabbitMQ架构模型 一、生产者和消费者 二、队列 三、交换器、路由键、绑定 Exchange:交换器。 Ra...

  • 消息队列Rabbitmq的交换器类型

    一、交换器类型 在rabbitmq中,生产者的消息都是通过交换器来接收,然后再从交换器分发到不同的队列中去,在分发...

  • RabbitMQ笔记

    1、消息队列 在介绍RabbitMQ之前先介绍一下消息队列,即MQ,(Message Queue) 消息队列是典型...

  • RabbitMQ,消息中间件的AMQP协议的结构

    知识要点: RabbitMQ几大组件 交换器类型 RabbitMQ运行流程 Connection与Channel ...

网友评论

      本文标题:【MQ】RabbitMQ 交换器与队列

      本文链接:https://www.haomeiwen.com/subject/lndfmktx.html