forked from decke/smtprelay
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmetrics.go
60 lines (49 loc) · 1.63 KB
/
metrics.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
package main
import (
"net/http"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
"github.com/prometheus/client_golang/prometheus/promhttp"
)
var (
requestsCounter prometheus.Counter
errorsCounter *prometheus.CounterVec
durationHistogram *prometheus.HistogramVec
msgSizeHistogram prometheus.Histogram
)
const mb = 1024 * 1024
func registerMetrics() {
requestsCounter = promauto.NewCounter(prometheus.CounterOpts{
Namespace: "smtprelay",
Name: "requests_count",
Help: "count of message relay requests",
})
errorsCounter = promauto.NewCounterVec(prometheus.CounterOpts{
Namespace: "smtprelay",
Name: "errors_count",
Help: "count of unsuccessfully relayed messages",
}, []string{"error_code"})
durationHistogram = promauto.NewHistogramVec(prometheus.HistogramOpts{
Namespace: "smtprelay",
Name: "request_duration",
Buckets: prometheus.DefBuckets,
}, []string{"error_code"})
msgSizeHistogram = promauto.NewHistogram(prometheus.HistogramOpts{
Namespace: "smtprelay",
Name: "message_bytes",
Buckets: []float64{0.05 * mb, 0.1 * mb, 0.25 * mb, 0.5 * mb, 1 * mb, 2 * mb, 5 * mb, 10 * mb, 20 * mb},
})
}
func handleMetrics() {
registerMetrics()
http.Handle("/", http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
_, _ = w.Write([]byte("OK"))
}))
http.Handle("/metrics", promhttp.Handler())
log.WithField("address", *metricsListen).
Info("starting metrics server")
if err := http.ListenAndServe(*metricsListen, nil); err != nil {
log.WithField("err", err.Error()).
Fatal("cannot publish metrics")
}
}