-
Notifications
You must be signed in to change notification settings - Fork 172
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
OM 2.0: Consider using complex values instead of suffixes #283
Comments
With Native Histograms stabilizing, is there a scenario where a user would prefer classic histograms over native histograms? If not, should we invest effort in this? 😅
We also planned to move _created to something similar to the way we handle metadata. Would that be enough for classic histograms as well? In our first call, we mentioned that one of our intentions with 2.0 is not to break the Prometheus user base to make the spec more favorable to other specs, so I'm not sure how we could commit to this one 😬 |
I think this would be great to consider, thanks! Essentially it removes metric family notion. We kind of do similar in protobuf format already. Also parses could generate non-complex types for classic histograms and summaries if needed. Two extra downsides to think about:
|
Yes and we could simply do the NHCB (custom buckets) straight in the text too. |
How it is breaking? While it would cause parser redesign, you can represent the current Prometheus model just fine with this idea, no? |
Added to the list of cons. |
Unsurprisingly, i'm not the first one to suggest this. @bwplotka pointed me to https://github.com/prometheus/OpenMetrics/blob/main/legacy/markdown/protobuf_vs_text.md#implied-data-model, by @beorn7 which contains a much more thorough description of the tradeoffs involved with using single-line representations of complex types. |
Regarding |
Relevant thoughts from @beorn7 on the
|
Just adding some more arguments for this. Parsing text is getting quite problematic if you try to support all cases (discussion) For example parsing (broken?) OM text like this:
..and trying to notice the |
This deserves its own proposal, but i'll outline the broad idea here start the discussion and gather high-level feedback.
Idea
The idea is that we could use complex values for fixed bucket histograms, summaries, and counters, similar to what we plan to do for native histograms. In OM 1.0 and in the Prometheus text format, those types are represented using multiple series with suffixes and special labels (e.g.
_bucket
suffix, or thele
label for histograms). Counters are included here because they have a "total" and a "start time".Advantages
..._created
lines prometheus#6541 by supporting the created timestamp in the value.histogram: my_metric
vsgauge: my_metric_bucket
Disadvantages
sum(request_duration_seconds_count)
->histogram_count(sum(request_duration_seconds))
.Alternatives
We could only use a complex value for counters, to support the start time in addition to the value. For fixed-bucket histograms and summaries, keep the existing suffixes and labels, but use the "complex counter" value for cumulative series. For users that have migrated from summaries and fixed-bucket histograms to native histograms, this has most of the advantages of the above, without many of the disadvantages for users using summaries or fixed-bucket histograms.
The text was updated successfully, but these errors were encountered: