-
Notifications
You must be signed in to change notification settings - Fork 3.9k
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
storage{,/engine}: separate Raft application side effects, remove (Batch).Defer() #6286
Comments
All Raft command side effects make use of The second step is tightening access to |
This is the first step towards formalizing the split trigger as a side effect in the sense of cockroachdb#6286. With proposed-evaluated KV, we will have to attach a small amount of metadata to the WriteBatch containing the SplitTrigger based from which we have to deduce the necessary actions. I have more WIP which contains plumbing-type work, but have decided to take a step back and bring these changes in in small increments as a plethora of roadblocks is to be expected and cockroachdb#6144 may influence (and/or be influenced by) this work. Code movement only (and changing a few words around the boundary of the move) in this commit.
This is the first step towards formalizing the split trigger as a side effect in the sense of cockroachdb#6286. With proposed-evaluated KV, we will have to attach a small amount of metadata to the WriteBatch containing the SplitTrigger based from which we have to deduce the necessary actions. I have more WIP which contains plumbing-type work, but have decided to take a step back and bring these changes in in small increments as a plethora of roadblocks is to be expected and cockroachdb#6144 may influence (and/or be influenced by) this work. Code movement only (and changing a few words around the boundary of the move) in this commit.
Previously, a committed split would have the Store process that split via a `batch.Defer`. As part of cockroachdb#6286, this `batch.Defer` was removed and explicit metainformation is now passed up the callchain up to `(*Replica).processRaftCommand`, where it is translated to calls to the Store. A similar mechanism was previously used for passing up skipped intents, and that mechanism has been folded into this new one (with more side effects to be extracted in future work).
Previously, a committed split would have the Store process that split via a `batch.Defer`. As part of cockroachdb#6286, this `batch.Defer` was removed and explicit metainformation is now passed up the callchain up to `(*Replica).processRaftCommand`, where it is translated to calls to the Store. A similar mechanism was previously used for passing up skipped intents, and that mechanism has been folded into this new one (with more side effects to be extracted in future work).
Previously, a committed split would have the Store process that split via a `batch.Defer`. As part of cockroachdb#6286, this `batch.Defer` was removed and explicit metainformation is now passed up the callchain up to `(*Replica).processRaftCommand`, where it is translated to calls to the Store. A similar mechanism was previously used for passing up skipped intents, and that mechanism has been folded into this new one (with more side effects to be extracted in future work).
Starting from `applyRaftCommand`, refactor in preparation for cockroachdb#6286 (which at this point is "almost" closed, missing only a second audit and some refactoring which makes it *impossible* for those methods to do anything but use the batch). Due to the subtlety of this change, it should be a prime suspect for anomalies in the near future. The movement of code may have changed some test semantics in subtle ways, in the most dangerous case letting them pass while hiding a regression. However, most of the changes were relatively mechanical and appropriate care has been taken. Prepare `applyRaftCommand` for cockroachdb#6290. After that issue, `applyRaftCommand` will operate on a supplied `WriteBatch` and an associated protobuf containing information necessary to execute all relevant side effects. The `WriteBatch` will be constructed on the lease holder (by calling some new method which will contain much of what is now the part of `applyRaftCommand` leading down to `executeWriteBatch`). The heavy lifting here is removing all spurious side effects from the state machine methods multiplexed to via `(*Replica).executeCmd`. In particular, in this change we - remove a first handful of `(*Batch).Defer`s, introduced a type `proposalResult` which along with the `WriteBatch` must contain all the information necessary for applying the command. Sprinkled TODOs liberally to give a general sense of what's to be done. - hoist communicating MVCCStats delta to store and leave a TODO for the handling of `ReplicaCorruptionError`s. - isolate a maybeGossipSystemConfig trigger - remove all of the uses of `batch.Defer()` in `replica_command.go`, for instance on Split, Merge (required some stats cleanup), GC, TruncateLog, ChangeFrozen, RequestLease, TransferLease; lift their side effects appropriately as well - move call to `setDesc` to trigger - remove Defer in handleRaftReady - move checksum computation and verification to triggers - reset ContainsEstimates in split post-commit trigger (in effect moving that hack up from splitTrigger) - move lease success/error counter update to trigger
I declare this done. We've removed batch.Defer and |
See #6166.
Separate the side effects of Raft applications from *Replica and clearly separate the parts which can be moved pre-proposal as well as the parameters required for the post-proposal part. Most of these should come up naturally when trying to remove the (*Replica) receiver on most of the ReplicaCommands (LeaderLease, Put, ...) and manually going through the rest of the call stack up to processRaftCommand.
The text was updated successfully, but these errors were encountered: