From 3f08891ec852113d41a0537f65913d6dbdc174aa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20M=C3=BCller?= Date: Mon, 30 Nov 2020 13:49:32 +0100 Subject: [PATCH 1/4] Add a site property to explicitly enable health checks --- pkg/mentix/exchangers/exporters/promsd.go | 6 ++++++ pkg/mentix/meshdata/properties.go | 2 ++ 2 files changed, 8 insertions(+) diff --git a/pkg/mentix/exchangers/exporters/promsd.go b/pkg/mentix/exchangers/exporters/promsd.go index 66d86d269a..67065697e2 100755 --- a/pkg/mentix/exchangers/exporters/promsd.go +++ b/pkg/mentix/exchangers/exporters/promsd.go @@ -24,6 +24,7 @@ import ( "io/ioutil" "os" "path/filepath" + "strings" "github.com/rs/zerolog" @@ -68,6 +69,11 @@ func createBlackboxSDScrapeConfig(site *meshdata.Site, host string, endpoint *me labels := getScrapeTargetLabels(site, endpoint) + // Check if health checks are enabled for the endpoint; if they aren't, skip this endpoint + if enableHealthChecks := meshdata.GetPropertyValue(endpoint.Properties, meshdata.PropertyEnableHealthChecks, "false"); !strings.EqualFold(enableHealthChecks, "true") { + return nil + } + return &prometheus.ScrapeConfig{ Targets: []string{target}, Labels: labels, diff --git a/pkg/mentix/meshdata/properties.go b/pkg/mentix/meshdata/properties.go index 7dfb8f7a57..479a4631c6 100644 --- a/pkg/mentix/meshdata/properties.go +++ b/pkg/mentix/meshdata/properties.go @@ -25,6 +25,8 @@ const ( PropertyOrganization = "organization" // PropertyMetricsPath identifies the metrics path property. PropertyMetricsPath = "metrics_path" + // PropertyEnableHealthChecks identifies the enable health checks property. + PropertyEnableHealthChecks = "enable_health_checks" // PropertyAPIVersion identifies the API version property. PropertyAPIVersion = "api_version" ) From ed873af3998f5764c78c530154a6cc0c21212bda Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20M=C3=BCller?= Date: Mon, 30 Nov 2020 13:57:39 +0100 Subject: [PATCH 2/4] Add changelog --- changelog/unreleased/mentix-checks.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 changelog/unreleased/mentix-checks.md diff --git a/changelog/unreleased/mentix-checks.md b/changelog/unreleased/mentix-checks.md new file mode 100644 index 0000000000..928533b283 --- /dev/null +++ b/changelog/unreleased/mentix-checks.md @@ -0,0 +1,5 @@ +Enhancement: Support property to enable health checking on a service + +This update introduces a new service property called `ENABLE_HEALTH_CHECKS` that must be explicitly set to `true` if a service should be checked for its health status. This allows us to only enable these checks for partner sites only, skipping vendor sites. + +https://github.com/cs3org/reva/pull/1347 From 1ffc3773de3a2239eab81028e630db67f6c3967d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20M=C3=BCller?= Date: Tue, 1 Dec 2020 14:11:44 +0100 Subject: [PATCH 3/4] Add some more labels to Prometheus targets --- pkg/mentix/exchangers/exporters/promsd.go | 16 ++++++++++++---- pkg/mentix/meshdata/properties.go | 2 ++ 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/pkg/mentix/exchangers/exporters/promsd.go b/pkg/mentix/exchangers/exporters/promsd.go index 67065697e2..2c10c15a35 100755 --- a/pkg/mentix/exchangers/exporters/promsd.go +++ b/pkg/mentix/exchangers/exporters/promsd.go @@ -47,7 +47,7 @@ type PrometheusSDExporter struct { } func createMetricsSDScrapeConfig(site *meshdata.Site, host string, endpoint *meshdata.ServiceEndpoint) *prometheus.ScrapeConfig { - labels := getScrapeTargetLabels(site, endpoint) + labels := getScrapeTargetLabels(site, host, endpoint) // If a metrics path was specified as a property, use that one by setting the corresponding label if metricsPath := meshdata.GetPropertyValue(endpoint.Properties, meshdata.PropertyMetricsPath, ""); len(metricsPath) > 0 { @@ -67,7 +67,7 @@ func createBlackboxSDScrapeConfig(site *meshdata.Site, host string, endpoint *me return nil } - labels := getScrapeTargetLabels(site, endpoint) + labels := getScrapeTargetLabels(site, host, endpoint) // Check if health checks are enabled for the endpoint; if they aren't, skip this endpoint if enableHealthChecks := meshdata.GetPropertyValue(endpoint.Properties, meshdata.PropertyEnableHealthChecks, "false"); !strings.EqualFold(enableHealthChecks, "true") { @@ -80,14 +80,22 @@ func createBlackboxSDScrapeConfig(site *meshdata.Site, host string, endpoint *me } } -func getScrapeTargetLabels(site *meshdata.Site, endpoint *meshdata.ServiceEndpoint) map[string]string { - return map[string]string{ +func getScrapeTargetLabels(site *meshdata.Site, host string, endpoint *meshdata.ServiceEndpoint) map[string]string { + labels := map[string]string{ "__meta_mentix_site": site.Name, "__meta_mentix_site_type": meshdata.GetSiteTypeName(site.Type), "__meta_mentix_site_id": site.GetID(), + "__meta_mentix_host": host, "__meta_mentix_country": site.CountryCode, "__meta_mentix_service_type": endpoint.Type.Name, } + + // Get the gRPC port if the corresponding property has been set + if port := meshdata.GetPropertyValue(endpoint.Properties, meshdata.PropertyGRPCPort, ""); len(port) > 0 { + labels["__meta_mentix_grpc_port"] = port + } + + return labels } func (exporter *PrometheusSDExporter) registerScrapeCreators(conf *config.Configuration) error { diff --git a/pkg/mentix/meshdata/properties.go b/pkg/mentix/meshdata/properties.go index 479a4631c6..b4962b4b0e 100644 --- a/pkg/mentix/meshdata/properties.go +++ b/pkg/mentix/meshdata/properties.go @@ -25,6 +25,8 @@ const ( PropertyOrganization = "organization" // PropertyMetricsPath identifies the metrics path property. PropertyMetricsPath = "metrics_path" + // PropertyGRPCPort identifies the gRPC port property. + PropertyGRPCPort = "grpc_port" // PropertyEnableHealthChecks identifies the enable health checks property. PropertyEnableHealthChecks = "enable_health_checks" // PropertyAPIVersion identifies the API version property. From 83ba2ca59ea3d4ff8266678f70fcd73916576398 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20M=C3=BCller?= Date: Tue, 1 Dec 2020 15:46:26 +0100 Subject: [PATCH 4/4] Skip endpoints for BBE if no gRPC port is set --- pkg/mentix/exchangers/exporters/promsd.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/pkg/mentix/exchangers/exporters/promsd.go b/pkg/mentix/exchangers/exporters/promsd.go index 2c10c15a35..6a30cb763d 100755 --- a/pkg/mentix/exchangers/exporters/promsd.go +++ b/pkg/mentix/exchangers/exporters/promsd.go @@ -67,13 +67,18 @@ func createBlackboxSDScrapeConfig(site *meshdata.Site, host string, endpoint *me return nil } - labels := getScrapeTargetLabels(site, host, endpoint) - // Check if health checks are enabled for the endpoint; if they aren't, skip this endpoint if enableHealthChecks := meshdata.GetPropertyValue(endpoint.Properties, meshdata.PropertyEnableHealthChecks, "false"); !strings.EqualFold(enableHealthChecks, "true") { return nil } + labels := getScrapeTargetLabels(site, host, endpoint) + + // For health checks, the gRPC port must be set + if _, ok := labels["__meta_mentix_grpc_port"]; !ok { + return nil + } + return &prometheus.ScrapeConfig{ Targets: []string{target}, Labels: labels,