Roman Puchkovskiy created IGNITE-18499:
------------------------------------------

             Summary: Make IncomingSnapshotCopier behave closer to 
LocalSnapshotCopier
                 Key: IGNITE-18499
                 URL: https://issues.apache.org/jira/browse/IGNITE-18499
             Project: Ignite
          Issue Type: Improvement
            Reporter: Roman Puchkovskiy
             Fix For: 3.0.0-beta2


There are a few differences between {{IncomingSnapshotCopier}} and 
{{{}LocalSnapshotCopier{}}}. JRaft seems to be very sensitive to little changes 
in behavior because it relies on many invariants, some of them implicit, to 
function correctly. Hence it is best to have our copier mimic the stock one as 
fully as possible (where it's feasible).

Here are the differences:
 # On cancellation, the copier should be transferred to an erroneous state 
(using {{{}setError(){}}})
 # On closure, the copier should be cancelled
 # The stock copier does not invoke {{join()}} on cancellation, but our 
implementation does. On the one hand, waiting seems to make sense because it 
allows to save retries, but it's a difference from the stock logic which might 
be dangerous.
 # We should only set error if it has not been set yet; but our copier 
implementation usually does the opposite: if there is an error, it sets some 
other error



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to