1
$rabbitmqctl list_queues

Timeout: 60.0 seconds ...
Listing queues for vhost / ...
privateTransactionQ 2
amq.gen-o9dl3Zj7HxS50gkTC2xbBQ  0
task_queue  0

rabbitmqctl 的输出如下所示。我无法弄清楚每列的含义。我怎样才能看到每列的含义?

4

1 回答 1

5

对此没有“简单”的解决方案,但我们是 IT 人员,我们可以构建它们。我不是 RabbitMQ 方面的专家,也不是编程方面的专家,但我会尽力给这个问题一个好的答案,以防有人来到这里寻求帮助。

让我们以从 rabbitmqctl 控制台列出队列的确切情况为例。通过键入“ rabbitmqctl ”,您可以获得可用命令的列表:

Commands: 
[...]
list_queues [-p <vhost>] [--online] [--offline] [--local] [<queueinfoitem> ...] [-t <timeout>]
[...] 

假设您知道什么是虚拟主机和队列,假设您想列出虚拟主机“ TEST ”中的所有队列,那么您需要输入:

> rabbitmqctil list_queues -p TEST 
Timeout: 60.0 seconds ...
Listing queues for vhost TEST ...
test.queue 0

默认情况下,您只会获得队列的“名称”及其“当前深度”。你在哪里找到队列的所有参数?请特别注意您首先键入的帮助说明中的“ queueinfoitem ”一词。如果您看到 rabbitmqctl 帮助说明(通过键入“rabbitmqctl”),在说明的末尾您可以看到参数“”的可用选项列表。

现在让我们看一个示例,您希望看到更高级的队列状态,例如:队列中准备好的消息、未确认状态的消息、消息 RAM、消费者、消费者的内存利用率、队列的状态,当然还有它的名称.

你是对的一件事:rabbitmqctl 不会以友好的方式返回结果。默认情况下,你会得到这个:

rabbitmqctl list_queues -p TEST  messages_ready, messages_unacknowledged, messages_ram, consumers, consumer_utilisation, state, name
Timeout: 60.0 seconds ...
Listing queues for vhost TEST ...
0       0       0       0               running test.queue

但只要有一点想象力,你就可以做到这一点:

----------------------------------------------------------
Msg. * Msg. * Msg. **       ** Cons. **         **** Name
Rdy * Unack * RAM *** Cons.  * Util. ** State    ***
----------------------------------------------------------
0       0       0       0               running     test.queue

这没什么大不了的,但比默认的要好。我用一个小的python脚本实现了这一点:

import os
vhosts = os.popen("rabbitmqctl list_vhosts name").read() 
logging.info(vhosts)
vhosts = vhosts.split("\n",1)[1]
vhosts = vhosts[:-1]
vhosts = vhosts.split("\n")
for vhost in vhosts: 
    header_a = "Msg. * Msg. * Msg. **       ** Cons. **         **** Name\n" 
    header_b = "Rdy * Unack * RAM *** Cons.  * Util. ** State    ***     \n"
    dash = "----------------------------------------------------------\n"
    queues = os.popen("rabbitmqctl list_queues -p " + vhost + " messages_ready, messages_unacknowledged, messages_ram, consumers, consumer_utilisation, state, name").read() 
    queues = queues.split("\n",2)[2]
    queues_list = dash + header_a + header_b + dash + queues
    print(queues_list)

当然,这可以通过很多方式进行改进,并且总是欢迎批评,我仍然希望它对某人有所帮助。

干杯。

于 2018-05-14T15:49:22.863 回答