mirror of
https://github.com/openfaas/faas.git
synced 2025-06-08 16:26:47 +00:00
- updates the Prometheus go client version and switches to the promhttp handler to avoid conflicts with the new system-level metrics. Tested with Docker Swarm locally - no conflicts and new metrics were gathered. Signed-off-by: Alex Ellis (VMware) <alexellis2@gmail.com>
92 lines
2.6 KiB
Go
92 lines
2.6 KiB
Go
// Copyright (c) Alex Ellis 2017. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
|
|
package metrics
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
|
)
|
|
|
|
// MetricOptions to be used by web handlers
|
|
type MetricOptions struct {
|
|
GatewayFunctionInvocation *prometheus.CounterVec
|
|
GatewayFunctionsHistogram *prometheus.HistogramVec
|
|
ServiceReplicasGauge *prometheus.GaugeVec
|
|
ServiceMetrics *ServiceMetricOptions
|
|
}
|
|
|
|
// ServiceMetricOptions provides RED metrics
|
|
type ServiceMetricOptions struct {
|
|
Histogram *prometheus.HistogramVec
|
|
Counter *prometheus.CounterVec
|
|
}
|
|
|
|
// PrometheusHandler Bootstraps prometheus for metrics collection
|
|
func PrometheusHandler() http.Handler {
|
|
return promhttp.Handler()
|
|
}
|
|
|
|
// BuildMetricsOptions builds metrics for tracking functions in the API gateway
|
|
func BuildMetricsOptions() MetricOptions {
|
|
gatewayFunctionsHistogram := prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Name: "gateway_functions_seconds",
|
|
Help: "Function time taken",
|
|
}, []string{"function_name"})
|
|
|
|
gatewayFunctionInvocation := prometheus.NewCounterVec(
|
|
prometheus.CounterOpts{
|
|
Name: "gateway_function_invocation_total",
|
|
Help: "Individual function metrics",
|
|
},
|
|
[]string{"function_name", "code"},
|
|
)
|
|
|
|
serviceReplicas := prometheus.NewGaugeVec(
|
|
prometheus.GaugeOpts{
|
|
Name: "gateway_service_count",
|
|
Help: "Docker service replicas",
|
|
},
|
|
[]string{"function_name"},
|
|
)
|
|
|
|
// For automatic monitoring and alerting (RED method)
|
|
histogram := prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Subsystem: "http",
|
|
Name: "request_duration_seconds",
|
|
Help: "Seconds spent serving HTTP requests.",
|
|
Buckets: prometheus.DefBuckets,
|
|
}, []string{"method", "path", "status"})
|
|
|
|
// Can be used Kubernetes HPA v2
|
|
counter := prometheus.NewCounterVec(
|
|
prometheus.CounterOpts{
|
|
Subsystem: "http",
|
|
Name: "requests_total",
|
|
Help: "The total number of HTTP requests.",
|
|
},
|
|
[]string{"status"},
|
|
)
|
|
|
|
serviceMetricOptions := &ServiceMetricOptions{
|
|
Counter: counter,
|
|
Histogram: histogram,
|
|
}
|
|
|
|
metricsOptions := MetricOptions{
|
|
GatewayFunctionsHistogram: gatewayFunctionsHistogram,
|
|
GatewayFunctionInvocation: gatewayFunctionInvocation,
|
|
ServiceReplicasGauge: serviceReplicas,
|
|
ServiceMetrics: serviceMetricOptions,
|
|
}
|
|
|
|
return metricsOptions
|
|
}
|
|
|
|
// RegisterExporter registers with Prometheus for tracking
|
|
func RegisterExporter(exporter *Exporter) {
|
|
prometheus.MustRegister(exporter)
|
|
}
|