4.8. 自动创建和删除地址和队列


您可以将代理配置为自动创建地址和队列,并在不再使用它们后删除它们。这样,在客户端可以连接到这个地址前,需要预先配置每个地址。

4.8.1. 自动创建和删除的配置选项

下表列出了配置 address-setting 元素时可用的配置元素,以自动创建和删除队列和地址。

表 4.3. 自动创建和删除队列和地址的配置元素
如果您希望 address-setting 变为…​添加此配置…​

当客户端发送消息到或尝试使用来自映射的队列的消息时,创建地址。

auto-create-addresses

当客户端发送消息到或尝试使用来自队列的消息时,创建队列。

auto-create-queues

当它不再有任何队列时,删除自动创建的地址。

auto-delete-addresses

当队列有 0 个消费者和 0 消息时,删除自动创建的队列。

auto-delete-queues

如果客户端没有指定,使用一个特定的路由类型。

default-address-routing-type

4.8.2. 配置自动创建和删除地址和队列

以下流程演示了如何配置自动创建和删除地址和队列。

流程

  1. 打开 & lt;broker_instance_dir> /etc/broker.xml 配置文件。
  2. 配置 address-setting 以自动创建和删除。以下示例使用上表中提到的所有配置元素。

    <configuration ...>
     <core ...>
      ...
      <address-settings>
        <address-setting match="activemq.#">
          <auto-create-addresses>true</auto-create-addresses>
          <auto-delete-addresses>true</auto-delete-addresses>
          <auto-create-queues>true</auto-create-queues>
          <auto-delete-queues>true</auto-delete-queues>
          <default-address-routing-type>ANYCAST</default-address-routing-type>
        </address-setting>
      </address-settings>
      ...
     </core>
    </configuration>
    address-setting
    address-setting 元素的配置应用于与通配符地址 activemq. 4.1 匹配的任何地址或队列。
    auto-create-addresses
    当客户端请求连接到尚不存在的地址时,代理会创建地址。
    auto-delete-addresses
    当自动创建的地址不再关联任何队列时,会删除自动创建的地址。
    auto-create-queues
    当客户端请求连接到尚未存在的队列时,代理会创建队列。
    auto-delete-queues
    当自动创建的队列不再有任何消费者或消息时,将删除自动创建的队列。
    default-address-routing-type
    如果客户端在连接时没有指定路由类型,代理会在向地址传递消息时使用 ANYCAST。默认值为 MULTICAST

其他资源

4.8.3. 协议管理器和地址

称为 协议管理器 的组件将特定于协议的概念映射到 AMQ Broker 地址模型、队列和路由类型中使用的概念。在某些情况下,协议管理器可能会在代理上自动创建队列。

例如,当客户端发送带有地址 /house/room1/lights/house/ room2/lights 的 MQTT 订阅数据包时,MQTT 协议管理器了解这两个地址需要 多播 语义。因此,协议管理器首先查找以确保两个地址都启用了 多播。如果没有,它会尝试动态创建它们。如果成功,协议管理器会为客户端请求的每个订阅创建特殊的订阅队列。

每个协议的行为略有不同。下表描述了在请求将帧订阅到各种 队列时 通常发生的情况。

表 4.4. 不同队列类型的协议管理器操作
如果队列是此类型…协议管理器的典型操作是 …​

持久化订阅队列

查找适当的地址并确保启用了 多播 语义。然后,它会创建一个特殊的订阅队列,客户端 ID 和地址作为其名称,multicast 作为路由类型。

特殊名称允许协议管理器快速识别所需的客户端订阅队列,应稍后断开连接和重新连接。

当客户端取消订阅队列时。

临时订阅队列

查找适当的地址并确保启用了 多播 语义。然后,它会在这个地址下创建一个带有 multicast 路由类型的随机(读取 UUID)名称的队列。

当客户端断开队列时,

点到点队列

查找适当的地址并确保启用了 anycast 路由类型。如果是,它旨在查找名称与地址相同的队列。如果不存在,它会查找第一个可用的队列。它不存在,然后它会自动创建队列(启用自动创建)。队列消费者绑定到此队列。

如果队列是自动创建的,则当没有消费者且没有消息后,它会自动删除。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.