Skip to content

Commit

Permalink
Decision: Shipping Metrics to Centralized Instance (#253)
Browse files Browse the repository at this point in the history
  • Loading branch information
bastjan authored Jun 5, 2023
1 parent be409a0 commit 18b3cf0
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
= Shipping Metrics to Centralized Instance

== Problem

We want to ship metrics from our OpenShift clusters to a centralized instance.
This will allow us to keep an overview over our managed clusters and keep us up-to-date on meta topics like managed upgrades.

OpenShift clusters may have millions of metrics, which - while technically easily possible - may come with a lot of resource usage, and thus cost.
To reduce spending we need to be able to select which metrics to ship to the centralized instance.


=== Goals

* Allow selecting metrics to be shipped to a centralized instance


=== Non-Goals

* Manage the centralized instance
* Manage scraping of metrics in the cluster


== Proposals

=== Ship all recording rules

All recording rules are shipped to the centralized instance.

This automatically ships alerts and many series from the OpenShift console dashboards.

It makes aggregation of metrics very easy and forces the user to think how and if the metrics should be aggregated.


=== Label metrics with a specific label if they should be shipped

Metrics that should be shipped are labeled with a static label like `ship: true`.
This moves the configuration very close to the metric implementation.

The labeling would need to be done in the ServiceMonitor or PodMonitor resources.
Most of those resources can't be edited or patched on OpenShift clusters.
This would make many metrics non-shippable.


=== Have an explicit list of time series to ship in the config hierarchy

We currently have a huge Regex in the Commodore hierarchy that selects metrics to be shipped.
This is hard to maintain and not very flexible.

Through some Jsonnet functions, building the Regex, we can engineer a better way to manage which metrics to ship.

This allows us to store the configuration in a single place and have it easily editable.


=== Use separate tooling to ship metrics

We could use a separate tool to ship metrics to the centralized instance with more ergonomic shipping rules.

Grafana Agent has the exact same configuration as Prometheus and would not improve the configuration.
It would also require us to run another tool on the cluster.

Telegraf doesn't seem to be configurable and can't filter metrics.

There's some SaaS offerings, such as NewRelic, that have fancier filtering options.
They're not free and would require us to ship metrics to a third party.


== Decision

We should ship all recording rules AND have an explicit list of time series to ship in the config hierarchy.


== Rationale

Shipping all recording rules is a manageable amount of metrics and gives us a head start on identifying the most important metrics.
It allows users to define recording rules for their own metrics and have them automatically shipped to the centralized instance.

Having an explicit list of time series to ship in the config hierarchy allows us to have a single source of truth for the metrics we want to ship.
Allows experimentation and makes shipping metrics more accessible to users.
1 change: 1 addition & 0 deletions docs/modules/ROOT/partials/nav.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -218,3 +218,4 @@
** xref:oc4:ROOT:explanations/decisions/syn-argocd-sharing.adoc[]
** xref:oc4:ROOT:explanations/decisions/multi-instance-argocd.adoc[]
** xref:oc4:ROOT:explanations/decisions/multi-team-alert-routing.adoc[]
** xref:oc4:ROOT:explanations/decisions/shipping-metrics-to-centralized-instance[]

0 comments on commit 18b3cf0

Please sign in to comment.