Skip to content
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

compare() returns fewer exemplars than expected #4284

Open
mapno opened this issue Nov 4, 2024 · 1 comment · May be fixed by #4292
Open

compare() returns fewer exemplars than expected #4284

mapno opened this issue Nov 4, 2024 · 1 comment · May be fixed by #4292
Assignees
Labels
area/query keepalive Label to exempt Issues / PRs from stale workflow type/bug Something isn't working

Comments

@mapno
Copy link
Member

mapno commented Nov 4, 2024

Context

Exemplars were added to TraceQL metrics in #3824. Queries such as {} | rate(), {} | quantile_over_time(duration, 0,99), {} | compare({status=error}) return exemplars if enabled.

Exemplars in compare() are only returned for the series __meta_type="selection_total" and __meta_type="baseline_total", since every other series is a subset of the totals, and exemplars carry all labels of the query.

Problem

Queries that use compare() are inconsistent in returning exemplars—usually return very few exemplars and only in some series, instead of in all series.

There are a couple of potential issues at hand here:

  • Sampling is very naive and the CallbackPredicate might be stopping collection too aggressively. The callback might be quitting before enough exemplars are collected.
  • Exemplars might not be propagated correctly to all series. There are multiple places where series are merged, and exemplars could be lost there. The first place is in the engine itself. But there are followup calls in the queriers, generators and frontends.
Copy link
Contributor

github-actions bot commented Jan 4, 2025

This issue has been automatically marked as stale because it has not had any activity in the past 60 days.
The next time this stale check runs, the stale label will be removed if there is new activity. The issue will be closed after 15 days if there is no new activity.
Please apply keepalive label to exempt this Issue.

@github-actions github-actions bot added the stale Used for stale issues / PRs label Jan 4, 2025
@mapno mapno added keepalive Label to exempt Issues / PRs from stale workflow and removed stale Used for stale issues / PRs labels Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/query keepalive Label to exempt Issues / PRs from stale workflow type/bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants