mirror of
https://github.com/imgproxy/imgproxy.git
synced 2025-01-23 11:14:48 +02:00
Add IMGPROXY_PROMETHEUS_NAMESPACE config (#405)
* Add IMGPROXY_PROMETHEUS_NAMESPACE config * Add documentations about IMGPROXY_PROMETHEUS_NAMESPACE Co-authored-by: Alexey Remizov <alexey.remizov@sport24.ru>
This commit is contained in:
parent
ebc7d0e644
commit
b783e8bebf
@ -232,6 +232,7 @@ type config struct {
|
|||||||
NewRelicKey string
|
NewRelicKey string
|
||||||
|
|
||||||
PrometheusBind string
|
PrometheusBind string
|
||||||
|
PrometheusNamespace string
|
||||||
|
|
||||||
BugsnagKey string
|
BugsnagKey string
|
||||||
BugsnagStage string
|
BugsnagStage string
|
||||||
@ -389,6 +390,7 @@ func configure() error {
|
|||||||
strEnvConfig(&conf.NewRelicKey, "IMGPROXY_NEW_RELIC_KEY")
|
strEnvConfig(&conf.NewRelicKey, "IMGPROXY_NEW_RELIC_KEY")
|
||||||
|
|
||||||
strEnvConfig(&conf.PrometheusBind, "IMGPROXY_PROMETHEUS_BIND")
|
strEnvConfig(&conf.PrometheusBind, "IMGPROXY_PROMETHEUS_BIND")
|
||||||
|
strEnvConfig(&conf.PrometheusNamespace, "IMGPROXY_PROMETHEUS_NAMESPACE")
|
||||||
|
|
||||||
strEnvConfig(&conf.BugsnagKey, "IMGPROXY_BUGSNAG_KEY")
|
strEnvConfig(&conf.BugsnagKey, "IMGPROXY_BUGSNAG_KEY")
|
||||||
strEnvConfig(&conf.BugsnagStage, "IMGPROXY_BUGSNAG_STAGE")
|
strEnvConfig(&conf.BugsnagStage, "IMGPROXY_BUGSNAG_STAGE")
|
||||||
|
@ -3,7 +3,9 @@
|
|||||||
imgproxy can collect its metrics for Prometheus. To use this feature, do the following:
|
imgproxy can collect its metrics for Prometheus. To use this feature, do the following:
|
||||||
|
|
||||||
1. Set `IMGPROXY_PROMETHEUS_BIND` environment variable. Note that you can't bind the main server and Prometheus to the same port;
|
1. Set `IMGPROXY_PROMETHEUS_BIND` environment variable. Note that you can't bind the main server and Prometheus to the same port;
|
||||||
2. Collect the metrics from any path on the specified binding.
|
2. Set `IMGPROXY_PROMETHEUS_NAMESPACE` to prepend prefix to the names of metrics.
|
||||||
|
I.e. with `IMGPROXY_PROMETHEUS_NAMESPACE=imgproxy` names will look like `imgproxy_requests_total`.
|
||||||
|
3. Collect the metrics from any path on the specified binding.
|
||||||
|
|
||||||
imgproxy will collect the following metrics:
|
imgproxy will collect the following metrics:
|
||||||
|
|
||||||
|
@ -32,56 +32,67 @@ func initPrometheus() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
prometheusRequestsTotal = prometheus.NewCounter(prometheus.CounterOpts{
|
prometheusRequestsTotal = prometheus.NewCounter(prometheus.CounterOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "requests_total",
|
Name: "requests_total",
|
||||||
Help: "A counter of the total number of HTTP requests imgproxy processed.",
|
Help: "A counter of the total number of HTTP requests imgproxy processed.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusErrorsTotal = prometheus.NewCounterVec(prometheus.CounterOpts{
|
prometheusErrorsTotal = prometheus.NewCounterVec(prometheus.CounterOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "errors_total",
|
Name: "errors_total",
|
||||||
Help: "A counter of the occurred errors separated by type.",
|
Help: "A counter of the occurred errors separated by type.",
|
||||||
}, []string{"type"})
|
}, []string{"type"})
|
||||||
|
|
||||||
prometheusRequestDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
prometheusRequestDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "request_duration_seconds",
|
Name: "request_duration_seconds",
|
||||||
Help: "A histogram of the response latency.",
|
Help: "A histogram of the response latency.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusDownloadDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
prometheusDownloadDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "download_duration_seconds",
|
Name: "download_duration_seconds",
|
||||||
Help: "A histogram of the source image downloading latency.",
|
Help: "A histogram of the source image downloading latency.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusProcessingDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
prometheusProcessingDuration = prometheus.NewHistogram(prometheus.HistogramOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "processing_duration_seconds",
|
Name: "processing_duration_seconds",
|
||||||
Help: "A histogram of the image processing latency.",
|
Help: "A histogram of the image processing latency.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusBufferSize = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
prometheusBufferSize = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "buffer_size_bytes",
|
Name: "buffer_size_bytes",
|
||||||
Help: "A histogram of the buffer size in bytes.",
|
Help: "A histogram of the buffer size in bytes.",
|
||||||
}, []string{"type"})
|
}, []string{"type"})
|
||||||
|
|
||||||
prometheusBufferDefaultSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
prometheusBufferDefaultSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "buffer_default_size_bytes",
|
Name: "buffer_default_size_bytes",
|
||||||
Help: "A gauge of the buffer default size in bytes.",
|
Help: "A gauge of the buffer default size in bytes.",
|
||||||
}, []string{"type"})
|
}, []string{"type"})
|
||||||
|
|
||||||
prometheusBufferMaxSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
prometheusBufferMaxSize = prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "buffer_max_size_bytes",
|
Name: "buffer_max_size_bytes",
|
||||||
Help: "A gauge of the buffer max size in bytes.",
|
Help: "A gauge of the buffer max size in bytes.",
|
||||||
}, []string{"type"})
|
}, []string{"type"})
|
||||||
|
|
||||||
prometheusVipsMemory = prometheus.NewGauge(prometheus.GaugeOpts{
|
prometheusVipsMemory = prometheus.NewGauge(prometheus.GaugeOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "vips_memory_bytes",
|
Name: "vips_memory_bytes",
|
||||||
Help: "A gauge of the vips tracked memory usage in bytes.",
|
Help: "A gauge of the vips tracked memory usage in bytes.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusVipsMaxMemory = prometheus.NewGauge(prometheus.GaugeOpts{
|
prometheusVipsMaxMemory = prometheus.NewGauge(prometheus.GaugeOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "vips_max_memory_bytes",
|
Name: "vips_max_memory_bytes",
|
||||||
Help: "A gauge of the max vips tracked memory usage in bytes.",
|
Help: "A gauge of the max vips tracked memory usage in bytes.",
|
||||||
})
|
})
|
||||||
|
|
||||||
prometheusVipsAllocs = prometheus.NewGauge(prometheus.GaugeOpts{
|
prometheusVipsAllocs = prometheus.NewGauge(prometheus.GaugeOpts{
|
||||||
|
Namespace: conf.PrometheusNamespace,
|
||||||
Name: "vips_allocs",
|
Name: "vips_allocs",
|
||||||
Help: "A gauge of the number of active vips allocations.",
|
Help: "A gauge of the number of active vips allocations.",
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user