File: op_counters.go

package info (click to toggle)
prometheus-mongodb-exporter 1.0.0%2Bgit20180522.e755a44-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 668 kB
  • sloc: sh: 65; makefile: 27
file content (74 lines) | stat: -rw-r--r-- 3,001 bytes parent folder | download | duplicates (3)
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
package collector

import (
	"github.com/prometheus/client_golang/prometheus"
)

var (
	opCountersTotal = prometheus.NewGaugeVec(prometheus.GaugeOpts{
		Namespace: Namespace,
		Name:      "op_counters_total",
		Help:      "The opcounters data structure provides an overview of database operations by type and makes it possible to analyze the load on the database in more granular manner. These numbers will grow over time and in response to database use. Analyze these values over time to track database utilization",
	}, []string{"type"})
)
var (
	opCountersReplTotal = prometheus.NewGaugeVec(prometheus.GaugeOpts{
		Namespace: Namespace,
		Name:      "op_counters_repl_total",
		Help:      "The opcountersRepl data structure, similar to the opcounters data structure, provides an overview of database replication operations by type and makes it possible to analyze the load on the replica in more granular manner. These values only appear when the current host has replication enabled",
	}, []string{"type"})
)

// OpcountersStats opcounters stats
type OpcountersStats struct {
	Insert  float64 `bson:"insert"`
	Query   float64 `bson:"query"`
	Update  float64 `bson:"update"`
	Delete  float64 `bson:"delete"`
	GetMore float64 `bson:"getmore"`
	Command float64 `bson:"command"`
}

// Export exports the data to prometheus.
func (opCounters *OpcountersStats) Export(ch chan<- prometheus.Metric) {
	opCountersTotal.WithLabelValues("insert").Set(opCounters.Insert)
	opCountersTotal.WithLabelValues("query").Set(opCounters.Query)
	opCountersTotal.WithLabelValues("update").Set(opCounters.Update)
	opCountersTotal.WithLabelValues("delete").Set(opCounters.Delete)
	opCountersTotal.WithLabelValues("getmore").Set(opCounters.GetMore)
	opCountersTotal.WithLabelValues("command").Set(opCounters.Command)

	opCountersTotal.Collect(ch)
}

// Describe describes the metrics for prometheus
func (opCounters *OpcountersStats) Describe(ch chan<- *prometheus.Desc) {
	opCountersTotal.Describe(ch)
}

// OpcountersReplStats opcounters stats
type OpcountersReplStats struct {
	Insert  float64 `bson:"insert"`
	Query   float64 `bson:"query"`
	Update  float64 `bson:"update"`
	Delete  float64 `bson:"delete"`
	GetMore float64 `bson:"getmore"`
	Command float64 `bson:"command"`
}

// Export exports the data to prometheus.
func (opCounters *OpcountersReplStats) Export(ch chan<- prometheus.Metric) {
	opCountersReplTotal.WithLabelValues("insert").Set(opCounters.Insert)
	opCountersReplTotal.WithLabelValues("query").Set(opCounters.Query)
	opCountersReplTotal.WithLabelValues("update").Set(opCounters.Update)
	opCountersReplTotal.WithLabelValues("delete").Set(opCounters.Delete)
	opCountersReplTotal.WithLabelValues("getmore").Set(opCounters.GetMore)
	opCountersReplTotal.WithLabelValues("command").Set(opCounters.Command)

	opCountersReplTotal.Collect(ch)
}

// Describe describes the metrics for prometheus
func (opCounters *OpcountersReplStats) Describe(ch chan<- *prometheus.Desc) {
	opCountersReplTotal.Describe(ch)
}