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

140 lines
4.0 KiB
Go
Raw Normal View History

2018-10-29 18:04:47 +06:00
package main
import (
"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{
Name: "requests_total",
Help: "A counter of the total number of HTTP requests imgproxy processed.",
})
prometheusErrorsTotal = prometheus.NewCounterVec(prometheus.CounterOpts{
Name: "errors_total",
2019-02-01 17:53:46 +06:00
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{
Name: "request_duration_seconds",
Help: "A histogram of the response latency.",
})
prometheusDownloadDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
Name: "download_duration_seconds",
Help: "A histogram of the source image downloading latency.",
})
prometheusProcessingDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
Name: "processing_duration_seconds",
Help: "A histogram of the image processing latency.",
})
2019-01-28 22:18:54 +06:00
prometheusBufferSize = prometheus.NewHistogramVec(prometheus.HistogramOpts{
2019-01-31 14:56:51 +06:00
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{
2019-01-31 14:56:51 +06:00
Name: "buffer_default_size_bytes",
Help: "A gauge of the buffer default size in bytes.",
}, []string{"type"})
prometheusBufferMaxSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
2019-01-31 14:56:51 +06:00
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{
Name: "vips_memory_bytes",
Help: "A gauge of the vips tracked memory usage in bytes.",
})
prometheusVipsMaxMemory = prometheus.NewGauge(prometheus.GaugeOpts{
Name: "vips_max_memory_bytes",
Help: "A gauge of the max vips tracked memory usage in bytes.",
})
prometheusVipsAllocs = prometheus.NewGauge(prometheus.GaugeOpts{
Name: "vips_allocs",
Help: "A gauge of the number of active vips allocations.",
})
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
2019-06-27 14:00:39 +06:00
s := http.Server{Handler: promhttp.Handler()}
2018-10-29 18:04:47 +06:00
go func() {
2019-06-27 14:00:39 +06:00
l, err := listenReuseport("tcp", conf.PrometheusBind)
if err != nil {
logFatal(err.Error())
}
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 {
2019-01-11 21:01:48 +06:00
logFatal(err.Error())
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))
}