A plugin for exporting RabbitMQ metrics collected by the Management Plugin to AWS CloudWatch.
Download the .ez files from the latest release and copy them into the RabbitMQ plugins directory.
Enable the plugin:
[sudo] rabbitmq-plugins enable rabbitmq_cloudwatch_exporterPlease see RabbitMQ Plugin Development guide.
To build the plugin:
git clone https://github.com/noxdafox/rabbitmq-cloudwatch-exporter.git
cd rabbitmq-cloudwatch-exporter
make distThen copy all the *.ez files inside the plugins folder to the RabbitMQ plugins directory and enable the plugin:
[sudo] rabbitmq-plugins enable rabbitmq_cloudwatch_exporterTo resolve AWS credentials, the standard environment variables AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY are looked up first. Otherwise, the EC2 instance role or ECS task role are employed.
To resolve AWS credentials, the standard environment variables AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY are looked up first. Otherwise, the EC2 instance role or ECS task role are employed.
Alternatively, the User can specify them in the rabbitmq.conf file as follows.
cloudwatch_exporter.aws.access_key_id = "AKIAIOSFODNN7EXAMPLE"
cloudwatch_exporter.aws.secret_access_key = "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"Or in the rabbitmq.config format.
[{rabbitmq_cloudwatch_exporter,
  [{aws, [{access_key_id, "AKIAIOSFODNN7EXAMPLE"},
          {secret_access_key, "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"}]}]}].By default the metrics are published within the us-east-1 AWS region. The region can be changed in the rabbitmq.conf file as follows.
cloudwatch_exporter.aws.region = "us-west-1"Or in the rabbitmq.config format.
[{rabbitmq_cloudwatch_exporter,
  [{aws, [{region, "us-west-1"}]}]}].Metrics are grouped in different categories described below. Each category must be enabled in the configuration in order for its metrics to be exported.
rabbitmq.conf example.
cloudwatch_exporter.metrics.overview.enable = true
cloudwatch_exporter.metrics.vhost.enable = true
# Omitting or setting a group to false is equivalent
cloudwatch_exporter.metrics.node.enable = falserabbitmq.config example.
[{rabbitmq_cloudwatch_exporter,
  [{metrics, [{overview, [{enable, true}]},
              {vhost, [{enable, true}]},
              {node, [{enable, false}]}]}]}].If a metrics group is enabled, all its metrics will be exported. The export_metrics configuration parameter allows to further limit which metrics of a specific group to export.
rabbitmq.conf example.
cloudwatch_exporter.metrics.exchange.enable = true
cloudwatch_exporter.metrics.exchange.export_metrics.1 = "PublishIn"
cloudwatch_exporter.metrics.exchange.export_metrics.2 = "PublishOut"rabbitmq.config example.
[{rabbitmq_cloudwatch_exporter,
  [{metrics, [{exchange, [{enable, true},
                          {export_metrics, ["PublishIn", "PublishOut"]}]}]}]}].For exchange, queue, connection and channel metrics groups, it is possible to control the names of the entities to be published via regular expressions.
rabbitmq.conf example.
cloudwatch_exporter.metrics.exchange.enable = true
# Only export exchanges which names begin with foo or end with bar
cloudwatch_exporter.metrics.exchange.export_regex = "foo.*|.*bar"
cloudwatch_exporter.metrics.queue.enable = true
# Exclude server-named queues
cloudwatch_exporter.metrics.queue.export_regex = "^(?!amq.gen-.*).*$"rabbitmq.config example.
[{rabbitmq_cloudwatch_exporter,
  [{metrics, [{exchange, [{enable, true},
                          {export_regex, "foo.*|.*bar"}]},
              {queue, [{enable, true},
                       {export_regex, "^(?!amq.gen-.*).*$"}]}]}]}].Metrics are exported every minute. The export period can be expressed in seconds via the cloudwatch_exporter.export_period configuration parameter (rabbitmq_cloudwatch_exporter.export_period in rabbitmq.config format). CloudWatch metrics have a standard resolution of one minute. Therefore, publishing more than once per minute will results in the metrics being aggregated on the receiving end. The cloudwatch_exporter.storage_resolution configuration parameter (rabbitmq_cloudwatch_exporter.storage_resolution in rabbitmq.config format) allows to decrease the aggregation period to 1, 5, 10 or 30 seconds.
Lastly, the AWS CloudWatch namespace can be controlled via the cloudwatch_exporter.namespace configuration parameter (rabbitmq_cloudwatch_exporter.namespace in rabbitmq.config format). The default value is RabbitMQ.
Metrics are grouped in different categories. All the metrics grouped within a category are characterised by a set of dimensions which help to identify their belonging.
As AWS CloudWatch charges a monthly cost per each metric, the CloudWatch Exporter Plugin exports a limited subset of metrics which are deemed relevant. If a particular metric is missing, please open an Issue Ticket or submit a Pull Request to add it to the exported ones. For the same rationale, the CloudWatch Exporter Plugin only exports metrics from the categories which have been enabled in the configuration file.
| Name | Description | 
|---|---|
| Metric | "ClusterOverview" | 
| Cluster | Cluster name | 
| Name | Description | 
|---|---|
| Messages | Total message count within the cluster | 
| MessagesReady | Messages ready for deliver within the cluster | 
| MessagesUnacknowledged | Messages pending for acknowledgement within the cluster | 
| Ack | Messages acknowledged | 
| Confirm | Messages confirmed to publishers | 
| Deliver | Messages delivered to consumers | 
| DeliverGet | Messages delivered to consumers via basic.get | 
| DeliverNoAck | Messages delivered to consumers without acknowledgment | 
| Get | Amount of basic.get requests | 
| GetEmpty | Amount of basic.get requests over empty queue | 
| GetNoAck | Amount of basic.get requests without acknowledgement | 
| Publish | Messages published within the channel | 
| Redeliver | Messages redelivered | 
| ReturnUnroutable | Messages returned as non routable | 
| Name | Description | 
|---|---|
| Metric | "VHost" | 
| Cluster | Cluster name | 
| VHost | Virtual Host name | 
| Name | Description | 
|---|---|
| Messages | Total message count within the vhost | 
| MessagesReady | Messages ready for deliver within the vhost | 
| MessagesUnacknowledged | Messages pending for acknowledgement within the vhost | 
| Ack | Messages acknowledged | 
| Confirm | Messages confirmed to publishers | 
| Deliver | Messages delivered to consumers | 
| DeliverGet | Messages delivered to consumers via basic.get | 
| DeliverNoAck | Messages delivered to consumers without acknowledgment | 
| Get | Amount of basic.get requests | 
| GetEmpty | Amount of basic.get requests over empty queue | 
| GetNoAck | Amount of basic.get requests without acknowledgement | 
| Publish | Messages published within the channel | 
| Redeliver | Messages redelivered | 
| ReturnUnroutable | Messages returned as non routable | 
| Name | Description | 
|---|---|
| Metric | "Node" | 
| Cluster | Cluster name | 
| Node | Node name | 
| Type | Node type (disk|memory) | 
| Limit | Limit when applicable | 
| Name | Description | 
|---|---|
| Uptime | Node uptime in milliseconds | 
| Memory | Memory in use | 
| DiskFree | Amount of free disk | 
| FileDescriptors | Open file descriptors | 
| Sockets | Open sockets | 
| Processes | Erlang Processes | 
| IORead | I/O read count | 
| BytesIORead | I/O read in bytes | 
| IOWrite | I/O write count | 
| BytesIOWrite | I/O write in bytes | 
| IOSeek | I/O seek count | 
| MnesiaRamTransactions | Mnesia transaction count on memory tables | 
| MnesiaDiskTransactions | Mnesia transaction count on disk tables | 
| Name | Description | 
|---|---|
| Metric | "Exchange" | 
| Cluster | Cluster name | 
| Exchange | Exchange name, _for the default exchange | 
| Type | Exchange type (direct|fanout|...) | 
| VHost | VHost where the exchange belongs | 
| Name | Description | 
|---|---|
| PublishIn | Messages published within the exchange | 
| PublishOut | Messages published by the exchange | 
| Name | Description | 
|---|---|
| Metric | "Queue" | 
| Cluster | Cluster name | 
| Queue | Queue name | 
| VHost | VHost where the queue belongs | 
| Name | Description | 
|---|---|
| Memory | Memory consumed by the queue | 
| Consumers | Consumers reading from the queue | 
| Messages | Total message count within the queue | 
| MessagesReady | Messages ready for deliver within the queue | 
| MessagesUnacknowledged | Messages pending for acknowledgement within the queue | 
| LengthPriorityLevel{level} | Number of elements in the priority level of the queue (only for priority queues) | 
| Ack | Messages acknowledged | 
| Deliver | Messages delivered to consumers | 
| DeliverGet | Messages delivered to consumers via basic.get | 
| DeliverNoAck | Messages delivered to consumers without acknowledgment | 
| Get | Amount of basic.get requests | 
| GetEmpty | Amount of basic.get requests over empty queue | 
| GetNoAck | Amount of basic.get requests without acknowledgement | 
| Publish | Messages published within the queue | 
| Redeliver | Messages redelivered | 
| Name | Description | 
|---|---|
| Metric | "Connection" | 
| Cluster | Cluster name | 
| Connection | IP:Port -> IP:port | 
| Protocol | Used protocol (AMQP 0-9-1|AMQP 1.0|STOMP|...) | 
| Node | Node where the connection is attached to | 
| VHost | VHost where the connection is attached to | 
| User | Username used to connect | 
| AuthMechanism | Employed authentication mechanism | 
| Name | Description | 
|---|---|
| Channels | Opened channels count | 
| Sent | Packets sent | 
| BytesSent | Bytes sent | 
| Received | Packets received | 
| BytesReceived | Bytes received | 
| Name | Description | 
|---|---|
| Metric | "Channel" | 
| Cluster | Cluster name | 
| Connection | IP:Port -> IP:port | 
| Channel | IP:Port -> IP:port (channels on the connection) | 
| VHost | VHost where the connection is attached to | 
| User | Username used to connect | 
| Name | Description | 
|---|---|
| MessagesUnacknowledged | Messages pending acknowledgement on the channel | 
| MessagesUnconfirmed | Messages unconfirmed on the channel | 
| MessagesUncommitted | Messages uncommitted on the channel | 
| AknogwledgesUncommitted | Acknowledgements uncommitted on the channel | 
| PrefetchCount | Prefetch count (QoS) configured on the channel | 
| GlobalPrefetchCount | Global prefetch count (QoS) configured on the channel | 
| Ack | Messages acknowledged | 
| Confirm | Messages confirmed to publishers | 
| Deliver | Messages delivered to consumers | 
| DeliverGet | Messages delivered to consumers via basic.get | 
| DeliverNoAck | Messages delivered to consumers without acknowledgment | 
| Get | Amount of basic.get requests | 
| GetEmpty | Amount of basic.get requests over empty queue | 
| GetNoAck | Amount of basic.get requests without acknowledgement | 
| Publish | Messages published within the channel | 
| Redeliver | Messages redelivered | 
| ReturnUnroutable | Messages returned as non routable |