-
Notifications
You must be signed in to change notification settings - Fork 11
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
multiple exemplars per sample #34
Draft
krajorama
wants to merge
1
commit into
prometheus:main
Choose a base branch
from
krajorama:out-of-order-and-multi-exemplars
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,85 @@ | ||||||||||
## Multiple exemplars per sample | ||||||||||
|
||||||||||
* **Owners:** | ||||||||||
* György (krajo) Krajcsovits [@krajorama](https://github.com/krajorama/) [[email protected]](mailto:[email protected]) | ||||||||||
|
||||||||||
* **Implementation Status:** Not implemented | ||||||||||
|
||||||||||
* **Related Issues and PRs:** | ||||||||||
* Prometheus [Support for ingesting out of order exemplars](https://github.com/prometheus/prometheus/issues/13577) | ||||||||||
* Prometheus [WIP: tsdb: Add support for out-of-order exemplars](https://github.com/prometheus/prometheus/pull/13580) | ||||||||||
* Prometheus client model [How to add exemplars to pure Native Histograms](https://github.com/prometheus/client_model/issues/61) | ||||||||||
* Prometheus client golang [histograms: Support exemplars in pure Native Histograms](https://github.com/prometheus/client_golang/issues/1126) | ||||||||||
* Prometheus client golang [add native histogram exemplar support](https://github.com/prometheus/client_golang/pull/1471) | ||||||||||
* Prometheus [scrape: Enable ingestion of multiple exemplars per sample](https://github.com/prometheus/prometheus/pull/12557) | ||||||||||
* Prometheus [Native histograms: error on ingesting out-of-order exemplars](https://github.com/prometheus/prometheus/issues/12971) | ||||||||||
* Prometheus [Fix error on ingesting out-of-order exemplars](https://github.com/prometheus/prometheus/pull/13021) | ||||||||||
* Prometheus [Prometheus support parse exemplars from native histogram](https://github.com/prometheus/prometheus/pull/13488) | ||||||||||
* OTEL proto [Base-2 exponential histogram protocol support](https://github.com/open-telemetry/opentelemetry-proto/pull/322) | ||||||||||
|
||||||||||
* **Other docs or links:** | ||||||||||
* [OTEL histogram](https://opentelemetry.io/docs/specs/otel/metrics/data-model/#histogram) | ||||||||||
* [OTEL exemplars](https://opentelemetry.io/docs/specs/otel/metrics/data-model/#exemplars) | ||||||||||
|
||||||||||
> This proposal collects the requirements and implementation proposals for supporting multiple exemplars per sample, in particular for native histograms. | ||||||||||
|
||||||||||
## Why | ||||||||||
|
||||||||||
Currently the remote write protocol (1.0 and 2.0) processes exemplars individually, which means that if a native histogram has multiple exemplars, they may arrive in separate remote write requests, making it hard to decide if the exemplar is out of order it belonged to a previous set of exemplars and should be considered a duplicate. | ||||||||||
|
||||||||||
Currently there is no mapping of the "set of exemplars" per sample concept that is in Open Telemetry specification. | ||||||||||
|
||||||||||
### Pitfalls of the current solution | ||||||||||
|
||||||||||
In the current solution we have a circular buffer for all exemplars. The exemplars are organized into two lists. One list links all exemplars from oldest received to newest so that we can make space when maximum number of exemplars is hit on insert. The other link | ||||||||||
is per time series, linking exemplars from oldest to newest. Also there is a pointer to the latest exemplar per time series to be able to check for duplicates, out of order. | ||||||||||
Comment on lines
+34
to
+35
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Do you mean "the other list" rather than "the other link"? Would think this refers to the second list.
Suggested change
|
||||||||||
|
||||||||||
For availability purposes, exemplars are written to the WAL and are loaded on restart. | ||||||||||
|
||||||||||
Currently when a new exemplar is inserted, it is only compared to the latest exemplar for the time series in question. | ||||||||||
|
||||||||||
This has a couple of issues: | ||||||||||
|
||||||||||
* There is no interface to pass multiple exemplars to head.AppendExemplar, so multiple calls need to be made, increasing the call count and lock contention. | ||||||||||
* If a native histogram has 10 exemplars per scrape/sample and all are received in the same remote write request, we currently try appending all in a loop. We consider them out of order if all are out of order, but if there's a duplicate of the last stored exemplar or some are newer than the last stored exemplar, then we just ignore the old exemplars. | ||||||||||
* However the logic above fails if exemplars are received in multiple remote write requests, so the logic is a workaround at best. | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. [Nit]
Suggested change
|
||||||||||
* Also for the above logic to work, the exemplars must be ordered by timestamp, however not all clients, especially OTEL follow this, so the implementation needs to also sort the exemplars before applying them. | ||||||||||
|
||||||||||
If the current proposal for out of order support [Support for ingesting out of order exemplars](https://github.com/prometheus/prometheus/issues/13577) is implemented, the problems above go away, however it would mean executing a linear search for each of the 10 exemplars, which would probably have a huge overhead. | ||||||||||
|
||||||||||
## Goals | ||||||||||
|
||||||||||
Goals and use cases for the solution as proposed in [How](#how): | ||||||||||
|
||||||||||
* Solve the issue of exemplars being split across remote write messages. | ||||||||||
* Solve the efficiency issue. | ||||||||||
|
||||||||||
### Audience | ||||||||||
|
||||||||||
Prometheus maintainers. | ||||||||||
|
||||||||||
## Non-Goals | ||||||||||
|
||||||||||
N/A | ||||||||||
|
||||||||||
## How | ||||||||||
|
||||||||||
Explain the full overview of the proposed solution. Some guidelines: | ||||||||||
|
||||||||||
* Make it concise and **simple**; put diagrams; be concrete, avoid using “really”, “amazing” and “great” (: | ||||||||||
* How you will test and verify? | ||||||||||
* How you will migrate users, without downtime. How we solve incompatibilities? | ||||||||||
* What open questions are left? (“Known unknowns”) | ||||||||||
|
||||||||||
## Alternatives | ||||||||||
|
||||||||||
The section stating potential alternatives. Highlight the objections reader should have towards your proposal as they read it. Tell them why you still think you should take this path [[ref](https://twitter.com/whereistanya/status/1353853753439490049)] | ||||||||||
|
||||||||||
1. This is why not solution Z... | ||||||||||
|
||||||||||
## Action Plan | ||||||||||
|
||||||||||
The tasks to do in order to migrate to the new idea. | ||||||||||
|
||||||||||
* [ ] Task one <GH issue> | ||||||||||
* [ ] Task two <GH issue> ... |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit for consistency :)