forked from Syncano/rabbitmq_exporter
-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathexporter_overview.go
122 lines (100 loc) · 4.38 KB
/
exporter_overview.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package main
import (
"context"
"github.com/prometheus/client_golang/prometheus"
log "github.com/sirupsen/logrus"
)
func init() {
//RegisterExporter("overview", newExporterOverview)
}
var (
overviewLabels = []string{"cluster"}
overviewMetricDescription = map[string]*prometheus.GaugeVec{
"object_totals.channels": newGaugeVec("channels", "Number of channels.", overviewLabels),
"object_totals.connections": newGaugeVec("connections", "Number of connections.", overviewLabels),
"object_totals.consumers": newGaugeVec("consumers", "Number of message consumers.", overviewLabels),
"object_totals.queues": newGaugeVec("queues", "Number of queues in use.", overviewLabels),
"object_totals.exchanges": newGaugeVec("exchanges", "Number of exchanges in use.", overviewLabels),
"queue_totals.messages": newGaugeVec("queue_messages_global", "Number ready and unacknowledged messages in cluster.", overviewLabels),
"queue_totals.messages_ready": newGaugeVec("queue_messages_ready_global", "Number of messages ready to be delivered to clients.", overviewLabels),
"queue_totals.messages_unacknowledged": newGaugeVec("queue_messages_unacknowledged_global", "Number of messages delivered to clients but not yet acknowledged.", overviewLabels),
"message_stats.publish_details.rate": newGaugeVec("messages_publish_rate", "Rate at which messages are entering the server.", overviewLabels),
"message_stats.deliver_no_ack_details.rate": newGaugeVec("messages_deliver_no_ack_rate", "Rate at which messages are delivered to consumers that use automatic acknowledgements.", overviewLabels),
"message_stats.deliver_details.rate": newGaugeVec("messages_deliver_rate", "Rate at which messages are delivered to consumers that use manual acknowledgements.", overviewLabels),
}
rabbitmqVersionMetric = prometheus.NewGaugeVec(
prometheus.GaugeOpts{
Name: "rabbitmq_version_info",
Help: "A metric with a constant '1' value labeled by rabbitmq version, erlang version, node, cluster.",
},
[]string{"rabbitmq", "erlang", "node", "cluster"},
)
)
type exporterOverview struct {
overviewMetrics map[string]*prometheus.GaugeVec
nodeInfo NodeInfo
}
//NodeInfo presents the name and version of fetched rabbitmq
type NodeInfo struct {
Node string
RabbitmqVersion string
ErlangVersion string
ClusterName string
TotalQueues int
}
func newExporterOverview() *exporterOverview {
overviewMetricDescriptionActual := overviewMetricDescription
if len(config.ExcludeMetrics) > 0 {
for _, metric := range config.ExcludeMetrics {
if overviewMetricDescriptionActual[metric] != nil {
delete(overviewMetricDescriptionActual, metric)
}
}
}
return &exporterOverview{
overviewMetrics: overviewMetricDescriptionActual,
nodeInfo: NodeInfo{},
}
}
func (e exporterOverview) NodeInfo() NodeInfo {
return e.nodeInfo
}
func (e *exporterOverview) Collect(ctx context.Context, ch chan<- prometheus.Metric) error {
body, contentType, err := apiRequest(config, "overview")
if err != nil {
return err
}
reply, err := MakeReply(contentType, body)
if err != nil {
return err
}
rabbitMqOverviewData := reply.MakeMap()
e.nodeInfo.Node, _ = reply.GetString("node")
e.nodeInfo.ErlangVersion, _ = reply.GetString("erlang_version")
e.nodeInfo.RabbitmqVersion, _ = reply.GetString("rabbitmq_version")
e.nodeInfo.ClusterName, _ = reply.GetString("cluster_name")
e.nodeInfo.TotalQueues = (int)(rabbitMqOverviewData["object_totals.queues"])
rabbitmqVersionMetric.Reset()
rabbitmqVersionMetric.WithLabelValues(e.nodeInfo.RabbitmqVersion, e.nodeInfo.ErlangVersion, e.nodeInfo.Node, e.nodeInfo.ClusterName).Set(1)
log.WithField("overviewData", rabbitMqOverviewData).Debug("Overview data")
for key, gauge := range e.overviewMetrics {
if value, ok := rabbitMqOverviewData[key]; ok {
log.WithFields(log.Fields{"key": key, "value": value}).Debug("Set overview metric for key")
gauge.Reset()
gauge.WithLabelValues(e.nodeInfo.ClusterName).Set(value)
}
}
if ch != nil {
rabbitmqVersionMetric.Collect(ch)
for _, gauge := range e.overviewMetrics {
gauge.Collect(ch)
}
}
return nil
}
func (e exporterOverview) Describe(ch chan<- *prometheus.Desc) {
rabbitmqVersionMetric.Describe(ch)
for _, gauge := range e.overviewMetrics {
gauge.Describe(ch)
}
}