-
Notifications
You must be signed in to change notification settings - Fork 233
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
precompute min safe ts #622
Conversation
PTAL @Yisaer |
@@ -571,6 +556,18 @@ func (s *KVStore) updateSafeTS(ctx context.Context) { | |||
metrics.TiKVMinSafeTSGapSeconds.WithLabelValues(storeIDStr).Set(time.Since(safeTSTime).Seconds()) | |||
}(ctx, wg, storeID, storeAddr) | |||
} | |||
|
|||
txnScopeMap := make(map[string][]uint64) | |||
for _, store := range stores { |
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.
why not keep the original way
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.
sorry, what do you mean by original
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.
if store.IsLabelsMatch([]*metapb.StoreLabel{
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.
IsLabelsMatch
requires a specific value for the label, where here tries to precompute the min safe ts for all the labelled value
Signed-off-by: hihihuhu <[email protected]>
Signed-off-by: hihihuhu <[email protected]>
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.
LGTM
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.
LGTM
the failed test seems related to tikv/tikv#13866, @Connor1996 do you know how often the tikv nightly image is updated? |
It should be updated every day, but not a promise |
Thanks for your contribution! |
hi @sticnarf, qq: is there a chance that we could port this to upcoming v6.5? if possible, do you know how is the process? thanks! |
Update tikv-client in TiDB. And v6.5 branch has already been check-out, you need to cherry-pick it to v6.5 branch. But not sure if the cherry-pick would be approved as usually only bugfix is allowed to be merged after code freeze。 |
i c, thanks for the info |
compute the min safe ts on the query path is expensive because it has to allocate thousands of small objects with lock, when there are hundreds of tikv node. this makes stale read using session variable
tidb_read_staleness
noticeable slower than normal read.the safe ts from tikv are only updated every 2 seconds, thus the min safe ts could be precomputed on the update path to avoid the expensive computation on query path.
result on our benchmark
normal read:
data:image/s3,"s3://crabby-images/6a8ec/6a8ec10ffa7ca859c308f105b53c1502488324f3" alt="Screen Shot 2022-11-23 at 10 22 26 AM"
stale read before the change:
data:image/s3,"s3://crabby-images/42cc3/42cc3f6e16ed130c65793b62121b6c227be0c206" alt="Screen Shot 2022-11-23 at 10 22 45 AM"
data:image/s3,"s3://crabby-images/413d0/413d06324a84961cced4671f49578b2f0262e268" alt="Screen Shot 2022-11-23 at 10 23 00 AM"
zoom in:
stale read after the change:
data:image/s3,"s3://crabby-images/2a778/2a77888796fdf70a1ad8a2098bc999806d22e59c" alt="Screen Shot 2022-11-23 at 10 30 14 AM"
data:image/s3,"s3://crabby-images/40318/40318f495edd74cb6b286bb78ee1dfcd53bdcade" alt="Screen Shot 2022-11-23 at 10 31 05 AM"
zoom in:
to further reduce the cpu usage, could remove the warning logging from https://github.com/pingcap/tidb/blob/v6.5.0-alpha/expression/builtin_time.go#L6576