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

Add source label to query stats metrics #6470

Conversation

SungJin1212
Copy link
Contributor

This PR adds a source label to query stat metrics.

Use case

When the user enables -ruler.frontend-address, the query stat metrics get changed whenever the ruler evaluates the rules. In other words, the query stat metrics are influenced by ruler and other source even though the user wants to track the metrics only by other source.
This PR attaches the source label to address this situation.

Which issue(s) this PR fixes:
Fixes #

Checklist

  • Tests updated
  • Documentation added
  • CHANGELOG.md updated - the order of entries should be [CHANGE], [FEATURE], [ENHANCEMENT], [BUGFIX]

@dosubot dosubot bot added component/query-frontend component/rules Bits & bobs todo with rules and alerts: the ruler, config service etc. labels Jan 2, 2025
@SungJin1212 SungJin1212 force-pushed the Add-source-label-to-query-stats-metrics branch 2 times, most recently from 3f1344a to 7b3c0a1 Compare January 2, 2025 11:01
@dosubot dosubot bot added the lgtm This PR has been approved by a maintainer label Jan 3, 2025
@SungJin1212 SungJin1212 force-pushed the Add-source-label-to-query-stats-metrics branch from a5bde1a to b05ba9b Compare January 7, 2025 08:26
@SungJin1212 SungJin1212 force-pushed the Add-source-label-to-query-stats-metrics branch from b05ba9b to 3b48b9c Compare January 8, 2025 01:34
alanprot
alanprot previously approved these changes Jan 10, 2025
@alanprot alanprot dismissed their stale review January 10, 2025 21:21

Request changes

Comment on lines +221 to +222
source := tripperware.GetSource(r.Header.Get("User-Agent"))
f.rejectedQueries.WithLabelValues(reasonRequestBodySizeExceeded, source, userID).Inc()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we allow any different "user-agent" as source, we may have cardinality problem that could cause metrics explosions.

Maybe we could just sub categorize the ruler UA and Others?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

source := tripperware.GetSource(r.Header.Get("User-Agent"))

GetSource already categorizes it to API and Ruler

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh nice! LGTM

@alanprot alanprot merged commit f2361b2 into cortexproject:master Jan 10, 2025
17 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
component/query-frontend component/rules Bits & bobs todo with rules and alerts: the ruler, config service etc. lgtm This PR has been approved by a maintainer size/M
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants