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


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

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

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

如果您希望 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.# 匹配的任何地址或队列。
    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 的问题时,CNO 协议管理器了解这两个地址需要 多播 语义。因此,协议管理器首先会查找确保为这两个地址启用 多播。如果没有,它会尝试动态创建它们。如果成功,协议经理会为客户端请求的每个订阅创建特殊订阅队列。

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

如果队列为这个类型…​协议管理器的典型操作是…​

Durable 订阅队列

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

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

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

临时订阅队列

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

客户端断开与队列的连接后,将删除。

点到点队列

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

如果队列是自动创建的,则在没有使用者且其中没有消息时自动删除它。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.