mirror of https://github.com/fluxcd/flagger.git
74 lines
1.6 KiB
Go
74 lines
1.6 KiB
Go
package metrics
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
var crossoverServiceQueries = map[string]string{
|
|
"request-success-rate": `
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
envoy_cluster_name="{{ .Name }}-canary",
|
|
envoy_response_code!~"5.*"
|
|
}[{{ .Interval }}]
|
|
)
|
|
)
|
|
/
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
envoy_cluster_name="{{ .Name }}-canary"
|
|
}[{{ .Interval }}]
|
|
)
|
|
)
|
|
* 100`,
|
|
"request-duration": `
|
|
histogram_quantile(
|
|
0.99,
|
|
sum(
|
|
rate(
|
|
envoy_cluster_upstream_rq_time_bucket{
|
|
kubernetes_namespace="{{ .Namespace }}",
|
|
envoy_cluster_name="{{ .Name }}-canary"
|
|
}[{{ .Interval }}]
|
|
)
|
|
) by (le)
|
|
)`,
|
|
}
|
|
|
|
type CrossoverServiceObserver struct {
|
|
client *PrometheusClient
|
|
}
|
|
|
|
func (ob *CrossoverServiceObserver) GetRequestSuccessRate(name string, namespace string, interval string) (float64, error) {
|
|
query, err := ob.client.RenderQuery(name, namespace, interval, crossoverServiceQueries["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 *CrossoverServiceObserver) GetRequestDuration(name string, namespace string, interval string) (time.Duration, error) {
|
|
query, err := ob.client.RenderQuery(name, namespace, interval, crossoverServiceQueries["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
|
|
}
|