2018-02-05 22:00:47 +00:00
|
|
|
package forward
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/coredns/coredns/plugin"
|
|
|
|
|
|
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Variables declared for monitoring.
|
|
|
|
|
var (
|
|
|
|
|
RequestCount = prometheus.NewCounterVec(prometheus.CounterOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2020-03-26 09:17:33 +01:00
|
|
|
Name: "requests_total",
|
2018-02-05 22:00:47 +00:00
|
|
|
Help: "Counter of requests made per upstream.",
|
|
|
|
|
}, []string{"to"})
|
|
|
|
|
RcodeCount = prometheus.NewCounterVec(prometheus.CounterOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2020-03-26 09:17:33 +01:00
|
|
|
Name: "responses_total",
|
2020-06-24 12:54:03 +08:00
|
|
|
Help: "Counter of response made per upstream.",
|
2018-02-05 22:00:47 +00:00
|
|
|
}, []string{"rcode", "to"})
|
|
|
|
|
RequestDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
|
|
|
|
Name: "request_duration_seconds",
|
|
|
|
|
Buckets: plugin.TimeBuckets,
|
|
|
|
|
Help: "Histogram of the time each request took.",
|
|
|
|
|
}, []string{"to"})
|
|
|
|
|
HealthcheckFailureCount = prometheus.NewCounterVec(prometheus.CounterOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2020-03-26 09:17:33 +01:00
|
|
|
Name: "healthcheck_failures_total",
|
2019-08-09 00:27:53 +08:00
|
|
|
Help: "Counter of the number of failed healthchecks.",
|
2018-02-05 22:00:47 +00:00
|
|
|
}, []string{"to"})
|
|
|
|
|
HealthcheckBrokenCount = prometheus.NewCounter(prometheus.CounterOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2020-03-26 09:17:33 +01:00
|
|
|
Name: "healthcheck_broken_total",
|
2019-08-09 00:27:53 +08:00
|
|
|
Help: "Counter of the number of complete failures of the healthchecks.",
|
2018-02-05 22:00:47 +00:00
|
|
|
})
|
|
|
|
|
SocketGauge = prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2018-06-20 12:35:57 +02:00
|
|
|
Name: "sockets_open",
|
2018-02-23 15:02:05 +00:00
|
|
|
Help: "Gauge of open sockets per upstream.",
|
2018-02-05 22:00:47 +00:00
|
|
|
}, []string{"to"})
|
2020-02-04 07:59:08 -05:00
|
|
|
MaxConcurrentRejectCount = prometheus.NewCounter(prometheus.CounterOpts{
|
|
|
|
|
Namespace: plugin.Namespace,
|
|
|
|
|
Subsystem: "forward",
|
2020-03-26 09:17:33 +01:00
|
|
|
Name: "max_concurrent_rejects_total",
|
2020-02-04 07:59:08 -05:00
|
|
|
Help: "Counter of the number of queries rejected because the concurrent queries were at maximum.",
|
|
|
|
|
})
|
2018-02-05 22:00:47 +00:00
|
|
|
)
|