[
https://issues.apache.org/jira/browse/IGNITE-24056?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Roman Puchkovskiy updated IGNITE-24056:
---------------------------------------
Description:
If a Raft state machine (represented with a RaftGroupListener) starts executing
a batch of commands which is huge, there is no way to stop it midway (apart
from closing a storage it interacts with). This, among other things, does not
allow us to stop an Ignite node timely if some Raft node recovers from a huge
Raft log.
Here is how we can do it:
# As soon as Raft node's shutdown is initiated, make the currently executed
iterator return false from hasNext()
# When such an iterator 'finishes', complete all command closures that were
not handled due to an early stop with a ShutdownException
> Prompt stop of Raft state machines
> ----------------------------------
>
> Key: IGNITE-24056
> URL: https://issues.apache.org/jira/browse/IGNITE-24056
> Project: Ignite
> Issue Type: Improvement
> Reporter: Roman Puchkovskiy
> Assignee: Roman Puchkovskiy
> Priority: Major
> Labels: ignite-3
>
> If a Raft state machine (represented with a RaftGroupListener) starts
> executing a batch of commands which is huge, there is no way to stop it
> midway (apart from closing a storage it interacts with). This, among other
> things, does not allow us to stop an Ignite node timely if some Raft node
> recovers from a huge Raft log.
> Here is how we can do it:
> # As soon as Raft node's shutdown is initiated, make the currently executed
> iterator return false from hasNext()
> # When such an iterator 'finishes', complete all command closures that were
> not handled due to an early stop with a ShutdownException
--
This message was sent by Atlassian Jira
(v8.20.10#820010)