1
0
mirror of https://github.com/imgproxy/imgproxy.git synced 2025-01-23 11:14:48 +02:00
imgproxy/prometheus.go

158 lines
4.7 KiB
Go
Raw Normal View History

2018-10-29 18:04:47 +06:00
package main
import (
2020-02-27 21:44:59 +06:00
"context"
"fmt"
2018-10-29 18:04:47 +06:00
"net/http"
"time"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promhttp"
)
var (
prometheusEnabled = false
prometheusRequestsTotal prometheus.Counter
prometheusErrorsTotal *prometheus.CounterVec
prometheusRequestDuration prometheus.Histogram
prometheusDownloadDuration prometheus.Histogram
prometheusProcessingDuration prometheus.Histogram
2019-01-28 22:18:54 +06:00
prometheusBufferSize *prometheus.HistogramVec
prometheusBufferDefaultSize *prometheus.GaugeVec
prometheusBufferMaxSize *prometheus.GaugeVec
2019-02-21 20:55:16 +06:00
prometheusVipsMemory prometheus.Gauge
prometheusVipsMaxMemory prometheus.Gauge
prometheusVipsAllocs prometheus.Gauge
2018-10-29 18:04:47 +06:00
)
func initPrometheus() {
if len(conf.PrometheusBind) == 0 {
return
}
2018-10-29 18:04:47 +06:00
prometheusRequestsTotal = prometheus.NewCounter(prometheus.CounterOpts{
Namespace: conf.PrometheusNamespace,
Name: "requests_total",
Help: "A counter of the total number of HTTP requests imgproxy processed.",
2018-10-29 18:04:47 +06:00
})
prometheusErrorsTotal = prometheus.NewCounterVec(prometheus.CounterOpts{
Namespace: conf.PrometheusNamespace,
Name: "errors_total",
Help: "A counter of the occurred errors separated by type.",
2018-10-29 18:04:47 +06:00
}, []string{"type"})
prometheusRequestDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
Namespace: conf.PrometheusNamespace,
Name: "request_duration_seconds",
Help: "A histogram of the response latency.",
2018-10-29 18:04:47 +06:00
})
prometheusDownloadDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
Namespace: conf.PrometheusNamespace,
Name: "download_duration_seconds",
Help: "A histogram of the source image downloading latency.",
2018-10-29 18:04:47 +06:00
})
prometheusProcessingDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
Namespace: conf.PrometheusNamespace,
Name: "processing_duration_seconds",
Help: "A histogram of the image processing latency.",
2018-10-29 18:04:47 +06:00
})
2019-01-28 22:18:54 +06:00
prometheusBufferSize = prometheus.NewHistogramVec(prometheus.HistogramOpts{
Namespace: conf.PrometheusNamespace,
Name: "buffer_size_bytes",
Help: "A histogram of the buffer size in bytes.",
2019-01-28 22:18:54 +06:00
}, []string{"type"})
prometheusBufferDefaultSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
Namespace: conf.PrometheusNamespace,
Name: "buffer_default_size_bytes",
Help: "A gauge of the buffer default size in bytes.",
}, []string{"type"})
prometheusBufferMaxSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
Namespace: conf.PrometheusNamespace,
Name: "buffer_max_size_bytes",
Help: "A gauge of the buffer max size in bytes.",
}, []string{"type"})
2019-02-21 20:55:16 +06:00
prometheusVipsMemory = prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: conf.PrometheusNamespace,
Name: "vips_memory_bytes",
Help: "A gauge of the vips tracked memory usage in bytes.",
2019-02-21 20:55:16 +06:00
})
prometheusVipsMaxMemory = prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: conf.PrometheusNamespace,
Name: "vips_max_memory_bytes",
Help: "A gauge of the max vips tracked memory usage in bytes.",
2019-02-21 20:55:16 +06:00
})
prometheusVipsAllocs = prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: conf.PrometheusNamespace,
Name: "vips_allocs",
Help: "A gauge of the number of active vips allocations.",
2019-02-21 20:55:16 +06:00
})
2018-10-29 18:04:47 +06:00
prometheus.MustRegister(
prometheusRequestsTotal,
prometheusErrorsTotal,
prometheusRequestDuration,
prometheusDownloadDuration,
prometheusProcessingDuration,
2019-01-28 22:18:54 +06:00
prometheusBufferSize,
prometheusBufferDefaultSize,
prometheusBufferMaxSize,
2019-02-21 20:55:16 +06:00
prometheusVipsMemory,
prometheusVipsMaxMemory,
prometheusVipsAllocs,
2018-10-29 18:04:47 +06:00
)
prometheusEnabled = true
2020-02-27 21:44:59 +06:00
}
2018-10-29 18:04:47 +06:00
2020-02-27 21:44:59 +06:00
func startPrometheusServer(cancel context.CancelFunc) error {
2019-06-27 14:00:39 +06:00
s := http.Server{Handler: promhttp.Handler()}
2018-10-29 18:04:47 +06:00
2020-02-27 21:44:59 +06:00
l, err := listenReuseport("tcp", conf.PrometheusBind)
if err != nil {
return fmt.Errorf("Can't start Prometheus metrics server: %s", err)
}
2019-06-27 14:00:39 +06:00
2020-02-27 21:44:59 +06:00
go func() {
logNotice("Starting Prometheus server at %s", conf.PrometheusBind)
2019-06-27 14:00:39 +06:00
if err := s.Serve(l); err != nil && err != http.ErrServerClosed {
2020-02-27 21:44:59 +06:00
logError(err.Error())
2018-10-29 18:04:47 +06:00
}
2020-02-27 21:44:59 +06:00
cancel()
2018-10-29 18:04:47 +06:00
}()
2020-02-27 21:44:59 +06:00
return nil
2018-10-29 18:04:47 +06:00
}
func startPrometheusDuration(m prometheus.Histogram) func() {
t := time.Now()
return func() {
m.Observe(time.Since(t).Seconds())
}
}
func incrementPrometheusErrorsTotal(t string) {
prometheusErrorsTotal.With(prometheus.Labels{"type": t}).Inc()
}
2019-01-28 22:18:54 +06:00
2019-01-31 14:56:51 +06:00
func observePrometheusBufferSize(t string, size int) {
prometheusBufferSize.With(prometheus.Labels{"type": t}).Observe(float64(size))
2019-01-28 22:18:54 +06:00
}
2019-01-31 14:56:51 +06:00
func setPrometheusBufferDefaultSize(t string, size int) {
prometheusBufferDefaultSize.With(prometheus.Labels{"type": t}).Set(float64(size))
}
2019-01-31 14:56:51 +06:00
func setPrometheusBufferMaxSize(t string, size int) {
prometheusBufferMaxSize.With(prometheus.Labels{"type": t}).Set(float64(size))
}