-
Notifications
You must be signed in to change notification settings - Fork 3.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
storage: introduce fine-grained latch acquisition
Towards #32583. The current mechanism in place for declaring latches over MVCC keys only allows them to be declared at a fixed timestamp (on a per request basis). For split commands for e.g., we're interested in in declaring latches on different timestamps for the two sides of the split. Specifically we're interested in declaring a non-MVCC read latch over the LHS and a non-MVCC write latch over the RHS to be able to service reads during splits (requests without timestamps, i.e. the empty timestamp, are considered non-MVCC). The same ideas can be applied to range merges and lease transfers. This change allows requests to specify, during span declarations, whether said span would require an MVCC or non-MVCC access. The access mode would correspond to an MVCC or non-MVCC latch acquired over said span depending. This would allow the aforementioned optimizations possible. Release note: None
- Loading branch information
1 parent
b9dc16b
commit 15d0c2d
Showing
35 changed files
with
1,160 additions
and
398 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.