diff options
Diffstat (limited to 'deps/rabbitmq_cli/lib/rabbitmq/cli/diagnostics/commands/alarms_command.ex')
-rw-r--r-- | deps/rabbitmq_cli/lib/rabbitmq/cli/diagnostics/commands/alarms_command.ex | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/deps/rabbitmq_cli/lib/rabbitmq/cli/diagnostics/commands/alarms_command.ex b/deps/rabbitmq_cli/lib/rabbitmq/cli/diagnostics/commands/alarms_command.ex new file mode 100644 index 0000000000..7669a523eb --- /dev/null +++ b/deps/rabbitmq_cli/lib/rabbitmq/cli/diagnostics/commands/alarms_command.ex @@ -0,0 +1,77 @@ +## This Source Code Form is subject to the terms of the Mozilla Public +## License, v. 2.0. If a copy of the MPL was not distributed with this +## file, You can obtain one at https://mozilla.org/MPL/2.0/. +## +## Copyright (c) 2007-2020 VMware, Inc. or its affiliates. All rights reserved. + +defmodule RabbitMQ.CLI.Diagnostics.Commands.AlarmsCommand do + @moduledoc """ + Displays all alarms reported by the target node. + + Returns a code of 0 unless there were connectivity and authentication + errors. This command is not meant to be used in health checks. + """ + import RabbitMQ.CLI.Core.Platform, only: [line_separator: 0] + import RabbitMQ.CLI.Core.Alarms + + @behaviour RabbitMQ.CLI.CommandBehaviour + + use RabbitMQ.CLI.Core.AcceptsDefaultSwitchesAndTimeout + use RabbitMQ.CLI.Core.MergesNoDefaults + use RabbitMQ.CLI.Core.AcceptsNoPositionalArguments + use RabbitMQ.CLI.Core.RequiresRabbitAppRunning + + def run([], %{node: node_name, timeout: timeout}) do + # Example response when there are alarms: + # + # [ + # file_descriptor_limit, + # {{resource_limit,disk,hare@warp10},[]}, + # {{resource_limit,memory,hare@warp10},[]}, + # {{resource_limit,disk,rabbit@warp10},[]}, + # {{resource_limit,memory,rabbit@warp10},[]} + # ] + # + # The topmost file_descriptor_limit alarm is node-local. + :rabbit_misc.rpc_call(node_name, :rabbit_alarm, :get_alarms, [], timeout) + end + + def output([], %{node: node_name, formatter: "json"}) do + {:ok, %{"result" => "ok", "node" => node_name, "alarms" => []}} + end + + def output([], %{node: node_name}) do + {:ok, "Node #{node_name} reported no alarms, local or clusterwide"} + end + + def output(alarms, %{node: node_name, formatter: "json"}) do + local = local_alarms(alarms, node_name) + global = clusterwide_alarms(alarms, node_name) + + {:ok, + %{ + "result" => "ok", + "local" => alarm_lines(local, node_name), + "global" => alarm_lines(global, node_name), + "message" => "Node #{node_name} reported alarms" + }} + end + + def output(alarms, %{node: node_name}) do + lines = alarm_lines(alarms, node_name) + + {:ok, Enum.join(lines, line_separator())} + end + + use RabbitMQ.CLI.DefaultOutput + + def help_section(), do: :observability_and_health_checks + + def description(), do: "Lists resource alarms (local or cluster-wide) in effect on the target node" + + def usage, do: "alarms" + + def banner([], %{node: node_name}) do + "Asking node #{node_name} to report any known resource alarms ..." + end +end |