- 
                Notifications
    You must be signed in to change notification settings 
- Fork 834
Implement metadata api query params #6681
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
Implement metadata api query params #6681
Conversation
9895799    to
    3279526      
    Compare
  
            
          
                pkg/querier/metadata_handler.go
              
                Outdated
          
        
      | return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { | ||
| resp, err := m.MetricsMetadata(r.Context()) | ||
| limit := -1 | ||
| if s := r.FormValue("limit"); s != "" { | 
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.
These two parts are copy/paste - maybe worth converting into a func?
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.
Can we add an integration test?
Signed-off-by: SungJin1212 <[email protected]>
3279526    to
    7a34129      
    Compare
  
    | mm.mtx.RLock() | ||
| defer mm.mtx.RUnlock() | ||
| r := make([]*cortexpb.MetricMetadata, 0, len(mm.metricToMetadata)) | ||
| if req.Limit == 0 { | 
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.
This change is not backwards/forwards compatiable right?
For example, during a deployment, querier and ingesters can be using different version of Cortex. If querier is on an older version and ingesters on a newer version, then querier will invoke the ingester rpc without passing a limit.
In this case, ingesters will return empty metadata. Ideally we want the 0 value to be treated as limit is disabled.
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.
That's a good point. We should put this behind a feature flag to do 2 phase rollout
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.
Thanks for letting me know. I will add flags and an e2e test for that scenario.
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.
Ideally we want the 0 value to be treated as limit is disabled.
prometheus/prometheus#12862 There is an issue here.
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.
I added a feature flag here #6744.
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.
We should add metadata API to the backward compatibility test to catch the problem earlier.
| mm.mtx.RLock() | ||
| defer mm.mtx.RUnlock() | ||
| r := make([]*cortexpb.MetricMetadata, 0, len(mm.metricToMetadata)) | ||
| if req.Limit == 0 { | 
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.
That's a good point. We should put this behind a feature flag to do 2 phase rollout
| Limit: int64(limit), | ||
| LimitPerMetric: int64(limitPerMetric), | ||
| Metric: metric, | ||
| } | 
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.
If limit is set to 0, do we still need to send the request to Ingester? There is no result anyway
This PR implements the Prometheus metadata API query parameters (
limit,limit_per_metric, andmetric) on the Cortex to allow user to limit metadata to return.Which issue(s) this PR fixes:
Fixes #6679
Checklist
CHANGELOG.mdupdated - the order of entries should be[CHANGE],[FEATURE],[ENHANCEMENT],[BUGFIX]