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

Query: allow multiple deduplication label. #1362

Merged
merged 17 commits into from
Sep 16, 2019

Conversation

krasi-georgiev
Copy link
Contributor

@krasi-georgiev krasi-georgiev commented Jul 31, 2019

Closes: #1174

Changes

Can start the querier with multi replica labels like:

--query.replica-label=prometheus_replica --query.replica-label=service

querier api supports replicaLabels url param which will overwrite the --query.replica-label cli flag to allow dynamic deduplication at query time.

Signed-off-by: Krasi Georgiev <[email protected]>
Signed-off-by: Krasi Georgiev <[email protected]>
Signed-off-by: Krasi Georgiev <[email protected]>
Signed-off-by: Krasi Georgiev <[email protected]>
@krasi-georgiev krasi-georgiev marked this pull request as ready for review August 2, 2019 12:42
@krasi-georgiev krasi-georgiev changed the title [WIP] Query: allow multiple deduplication label. Query: allow multiple deduplication label. Aug 2, 2019
@krasi-georgiev
Copy link
Contributor Author

ping @bwplotka @brancz @squat

Copy link
Member

@povilasv povilasv left a comment

Choose a reason for hiding this comment

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

Nice work 🥇 don't really have anything to comment on :D

Would be great if somebody else would also take a look.

Copy link
Member

@brancz brancz left a comment

Choose a reason for hiding this comment

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

Generally this looks like the right direction, just confirming two things.

pkg/query/api/v1.go Outdated Show resolved Hide resolved
@@ -325,10 +325,10 @@ func (s *dedupSeriesSet) Next() bool {
// replica label if it exists
func (s *dedupSeriesSet) peekLset() labels.Labels {
lset := s.peek.Labels()
if lset[len(lset)-1].Name != s.replicaLabel {
if _, ok := s.replicaLabels[lset[len(lset)-1].Name]; !ok {
Copy link
Member

Choose a reason for hiding this comment

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

I would have expected that we need to verify each replica label here. I feel like I'm missing something about this logic though, can you explain what's happening here?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

If the last label is not in the replicaLabels list than no replica labels are set.
Replica labels are always at the end of the list so if the last one is not present in the s.replicaLabels map this guarantees that no replica labels need to be stripped.

If the last labels in the full list is a replica label than strip all replica labels by removing len(s.replicaLabels) labels from the full labels list.

Copy link
Member

Choose a reason for hiding this comment

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

Worth to comment this indeed.

Copy link
Member

@bwplotka bwplotka left a comment

Choose a reason for hiding this comment

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

Nice! Thanks for detailed tests and doc improvements.

Some suggestions and inconsistencies, otherwise LGTM

pkg/query/api/v1.go Outdated Show resolved Hide resolved
pkg/query/api/v1.go Outdated Show resolved Hide resolved
@@ -325,10 +325,10 @@ func (s *dedupSeriesSet) Next() bool {
// replica label if it exists
func (s *dedupSeriesSet) peekLset() labels.Labels {
lset := s.peek.Labels()
if lset[len(lset)-1].Name != s.replicaLabel {
if _, ok := s.replicaLabels[lset[len(lset)-1].Name]; !ok {
Copy link
Member

Choose a reason for hiding this comment

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

Worth to comment this indeed.

pkg/query/iter.go Outdated Show resolved Hide resolved
pkg/query/querier.go Outdated Show resolved Hide resolved
pkg/query/querier_test.go Show resolved Hide resolved
Copy link
Member

@bwplotka bwplotka left a comment

Choose a reason for hiding this comment

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

Awesome! I think this make sense.

There is a bug (type) but otherwise LGTM! (: Thanks and sorry for delay.

docs/components/query.md Outdated Show resolved Hide resolved
go.mod Outdated Show resolved Hide resolved
pkg/query/api/v1.go Outdated Show resolved Hide resolved
@@ -212,6 +230,7 @@ func (api *API) parsePartialResponseParam(r *http.Request) (enablePartialRespons
const partialResponseParam = "partial_response"
enablePartialResponse = api.enablePartialResponse

// Overwrite the cli flag when provided as a query parameter.
Copy link
Member

Choose a reason for hiding this comment

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

Did you mean to put this below?

Copy link
Member

Choose a reason for hiding this comment

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

Anyway I would be fine with just what we have in doc, so maybe we can drop this comment?

Copy link
Contributor Author

@krasi-georgiev krasi-georgiev Sep 12, 2019

Choose a reason for hiding this comment

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

No this is the right place and it is for the partialResponseParam
I prefer to keep the comment here as I was a bit confused why this is done this way when I first saw it.

Copy link
Member

Choose a reason for hiding this comment

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

Why you put it here then and not for parseDownsamplingParamMillis and parseReplicaLabelsParam? I don't get it ):

// Check how many replica labels are present so that these are removed.
var totalToRemove int
for index := 0; index < len(s.replicaLabels); index++ {
if _, ok := s.replicaLabels[lset[len(lset)-index-1].Name]; ok {
Copy link
Member

Choose a reason for hiding this comment

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

Nice, that might work nicely 👍

pkg/query/querier_test.go Show resolved Hide resolved
Signed-off-by: Krasi Georgiev <[email protected]>
@bwplotka
Copy link
Member

Copy link
Member

@bwplotka bwplotka left a comment

Choose a reason for hiding this comment

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

LGTM!

Thanks!

@@ -212,6 +230,7 @@ func (api *API) parsePartialResponseParam(r *http.Request) (enablePartialRespons
const partialResponseParam = "partial_response"
enablePartialResponse = api.enablePartialResponse

// Overwrite the cli flag when provided as a query parameter.
Copy link
Member

Choose a reason for hiding this comment

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

Why you put it here then and not for parseDownsamplingParamMillis and parseReplicaLabelsParam? I don't get it ):

@bwplotka bwplotka merged commit f4757f5 into thanos-io:master Sep 16, 2019
@krasi-georgiev
Copy link
Contributor Author

Why you put it here then and not for parseDownsamplingParamMillis and parseReplicaLabelsParam? I don't get it ):

I see what you mean now , yes that would be better to be as a comment to the function itself.

If I don't forget will open a PR.

wbh1 pushed a commit to wbh1/thanos that referenced this pull request Sep 17, 2019
@jojohappy jojohappy mentioned this pull request Sep 27, 2019
@krasi-georgiev krasi-georgiev deleted the multi-dedup-labels branch September 1, 2020 11:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Ability to use multiple dedup labels
4 participants