-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
fix reader getting wrong posting offsets when querying multiple values #7301
Conversation
c8e6e7e
to
0dc4c9b
Compare
@@ -173,6 +187,17 @@ func TestReaders(t *testing.T) { | |||
testutil.Assert(t, rngs[2].End > rngs[2].Start) | |||
testutil.Equals(t, NotFoundRange, rngs[1]) | |||
|
|||
// 3 values exist and 3 values don't exist. | |||
rngs, err = br.PostingsOffsets("cluster", "a-eu-west-1", "a-us-west-2", "b-eu-west-1", "b-us-east-1", "c-eu-west-1", "c-us-east-2") | |||
testutil.Ok(t, err) |
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.
Without this fix, it will cause error invalid index size
.
…ltiple values Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
Signed-off-by: Ben Ye <[email protected]>
130ff6a
to
61878fc
Compare
Signed-off-by: Ben Ye <[email protected]>
61878fc
to
7996766
Compare
Ok.. good catch. I had to pull this PR and run the test to see what was going on but now I understand. :P We could just add an extra validation on this lines as in this case the decoder buff also returned an error: thanos/pkg/block/indexheader/binary_reader.go Lines 947 to 949 in 17afd29
|
Thanks for the review. I am going to merge this pr since I believe this change is only used in lazy postings. |
thanos-io#7301) Signed-off-by: mluffman <[email protected]>
Changes
Index header reader has 2 methods to get posting offsets.
PostingsOffset
receives only a single value andPostingsOffsets
receives multiple values. Both methods rely on the same underlying functionpostingsOffset
to iterate over the posting offset table and get the index range.PostingsOffset
is used in Store Gateway for query andPostingsOffsets
is only used in lazy postings.For a given slice of values, we expect that both of them return the same index ranges, using the following code.
However, we observed that
PostingsOffsets
returned wrong index range when lazy expanded postings is enabled and querying multiple values. The bug is caused by https://github.com/thanos-io/thanos/blob/main/pkg/block/indexheader/binary_reader.go#L949 when the current index header reader is pointing to the last entry in the posting offset table but continue iterating further. This might causeinvalid index size
bug (reproduced in the new unit test I added) or wrong index range (end < start).Example returned index ranges. The last one
{517099476 111}
is wrong. Others are either not found range{-1, -1}
or normal range with start value (the first one) < end value (the second one)This will result in wrong cardinality calculation in lazy posting optimization and make the query performance worse. https://github.com/thanos-io/thanos/blob/main/pkg/store/lazy_postings.go#L64
Verification
I added a unit test to reproduce and also a test case to compare results from batched and non batched implementation.