mirror of
https://github.com/fluxcd/flagger.git
synced 2026-03-01 01:00:40 +00:00
- add observer interface with builtin metrics functions - add metrics observer factory - add prometheus client - implement the observer interface for istio, envoy and nginx - remove deprecated istio and app mesh metric aliases (istio_requests_total, istio_request_duration_seconds_bucket, envoy_cluster_upstream_rq, envoy_cluster_upstream_rq_time_bucket)
74 lines
1.6 KiB
Go
74 lines
1.6 KiB
Go
package metrics
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
var envoyQueries = map[string]string{
|
|
"request-success-rate": `
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
kubernetes_pod_name=~"{{ .Name }}-[0-9a-zA-Z]+(-[0-9a-zA-Z]+)",
|
|
envoy_response_code!~"5.*"
|
|
}[{{ .Interval }}]
|
|
)
|
|
)
|
|
/
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
kubernetes_pod_name=~"{{ .Name }}-[0-9a-zA-Z]+(-[0-9a-zA-Z]+)"
|
|
}[{{ .Interval }}]
|
|
)
|
|
)
|
|
* 100`,
|
|
"request-duration": `
|
|
histogram_quantile(
|
|
0.99,
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq_time_bucket{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
kubernetes_pod_name=~"{{ .Name }}-[0-9a-zA-Z]+(-[0-9a-zA-Z]+)"
|
|
}[{{ .Interval }}]
|
|
)
|
|
) by (le)
|
|
)`,
|
|
}
|
|
|
|
type EnvoyObserver struct {
|
|
client *PrometheusClient
|
|
}
|
|
|
|
func (ob *EnvoyObserver) GetRequestSuccessRate(name string, namespace string, interval string) (float64, error) {
|
|
query, err := ob.client.RenderQuery(name, namespace, interval, envoyQueries["request-success-rate"])
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
value, err := ob.client.RunQuery(query)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
return value, nil
|
|
}
|
|
|
|
func (ob *EnvoyObserver) GetRequestDuration(name string, namespace string, interval string) (time.Duration, error) {
|
|
query, err := ob.client.RenderQuery(name, namespace, interval, envoyQueries["request-duration"])
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
value, err := ob.client.RunQuery(query)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
ms := time.Duration(int64(value)) * time.Millisecond
|
|
return ms, nil
|
|
}
|