RabbitMQ 教程

rabbitmqctl 管理 Policy 策略

前面章节介绍了怎样使用 rabbitmq-management 插件提供的可视化界面管理 Policy 策略。下面将介绍使用 rabbitmqctl 命令来管理 Policy 策略。

设置 Policy 策略

在 RabbitMQ 中,可以使用 rabbitmqctl set_policy 命令来设置一个 Policy。命令格式如下:

rabbitmqctl set_policy [-p vhost] [--priority priority] [--apply-to apply-to] {name} {pattern} {definition}

其中的参数含义如下:

  • -p:指定虚拟机,如:/

  • --priority:指定优先级

  • --apply-to:指定该 Policy 的应用范围,如:同时应用到交换器和队列

  • name:指定 Policy 的名称

  • pattern:指定 Policy 匹配交换器或队列的正则表达式,如:^policy.+

  • definition:指定属性,如:message-ttl 等

示例:设置默认虚拟机(vhost)中所有以 “policy” 开头的队列的策略。其中,Policy 优先级为1,仅仅应用到队列,匹配模式为“^policy.+”,且消息的 ttl 为 3 秒。如下:

C:\Users\Administrator> rabbitmqctl set_policy --apply-to queues --priority 1 myPolicy "^policy.+" "{\"message-ttl\":3000}"
Setting policy "myPolicy" for pattern "^policy.+" to "{"message-ttl":3000}" with priority "1" for vhost "/" ...

列举 Policy 策略

在 RabbitMQ 中,可以使用 rabbitmqctl list_policies 命令列出默认虚拟机中所有的 Policy。命令格式:

rabbitmqctl list_policies [-p vhost]

示例

(1)列出默认虚拟机中所有的 Policy

C:\Users\Administrator> rabbitmqctl list_policies
Listing policies for vhost "/" ...
vhost   name    pattern apply-to        definition      priority
/       myPolicy        ^policy.+       queues  {"message-ttl":3000}    1
/       test-policy     ^policy.+       queues  {"message-ttl":3000}    1

(2)列出 vhost1 虚拟机中所有的 Policy

C:\Users\Administrator> rabbitmqctl list_policies -p vhost1
Listing policies for vhost "vhost1" ...
vhost   name    pattern apply-to        definition      priority
vhost1  policyDemo      ^policy.+       queues  {"message-ttl":3000}    1

清除 Policy 策略

在 RabbitMQ 中,可以使用 rabbitmqctl clear_policy 命令清除指定的 Policy。命令格式:

rabbitmqctl clear_policy [-p vhost] {name}

其中,name 表示 Policy 名称。

示例:删除默认虚拟机中名为 myPolicy 的 Policy 策略。命令如下:

# 列出默认虚拟机下所有 Policy
C:\Users\Administrator> rabbitmqctl list_policies
Listing policies for vhost "/" ...
vhost   name    pattern apply-to        definition      priority
/       myPolicy        ^policy.+       queues  {"message-ttl":3000}    1
/       test-policy     ^policy.+       queues  {"message-ttl":3000}    1

# 清理名为 myPolicy 的 Policy
C:\Users\Administrator> rabbitmqctl clear_policy myPolicy
Clearing policy "myPolicy" on vhost "/" ...

# 列出默认虚拟机下所有 Policy
C:\Users\Administrator> rabbitmqctl list_policies
Listing policies for vhost "/" ...
vhost   name    pattern apply-to        definition      priority
/       test-policy     ^policy.+       queues  {"message-ttl":3000}    1

如果有两个或多个 Policy 都作用到同一个交换器或者队列上,且这些 Policy 的优先级都是一样的,则参数项最多的 Policy 优先。如果参数一样多,则最后添加的 Policy 优先。

说说我的看法
全部评论(
没有评论
关于
本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,请来信告知:hxstrive@outlook.com
公众号