Skip to content

Files

Latest commit

1c2587f · Nov 10, 2022

History

History
39 lines (32 loc) · 2.57 KB

async_replication.md

File metadata and controls

39 lines (32 loc) · 2.57 KB

Asynchronous Replication

The original Raft's commit happens after reaching the quorum, which means that network communication is always involved in users' operation paths.

However, there are some loosened cases where we want to achieve low latency by sacrificing consistency and resolving conflicts manually. Then waiting for the acknowledgment from a majority of servers is a waste of time.

To support such cases, we provide async_replication_ flag in cluster_config. If that flag is set, append_entries() API immediately returns with the result of state_machine::pre_commit(), and replication is done in background later.

The below diagram shows the overall flow. You can compare it with original sequence:

User    Leader  Follower(s)
|       |       |
X------>|       |   raft_server::append_entries()
|       X       |   log_store::append()
|       X       |   RESULT <- state_machine::pre_commit()
|<------X       |   Return with RESULT
|       X------>|   Send logs
|       |      (X)  (if conflict) state_machine::rollback()
|       |      (X)  (if conflict) log_store::write_at()
|       |      (X)  (if conflict) state_machine::pre_commit()
|       |       X   log_store::append()
|       |       X   state_machine::pre_commit()
|       |      (X)  (commit of previous logs) state_machine::commit()
|       |<------X   Respond
|       X       |   state_machine::commit()
|       |       |

To enable asynchronous replication, state_machine::pre_commit() function should do the actual execution, instead of state_machine::commit(). In addition to that, you also should implement state_machine::rollback() correctly, to revert any changes done by pre_commit().

In synchronous replication mode, we provide another option: async_handler in raft_params. Here are the differences between asynchronous replication mode and synchronous replication with async_handler mode:

  • Synchronous replication with async_handler mode:
    • The actual execution in the state machine happens after reaching consensus.
    • Although append_entries() API returns immediately, the given data is not committed yet. The result of commit() will be set later by invoking a user-defined handler as a notification.
  • Asynchronous replication mode:
    • The actual execution in the state machine happens before replication.
    • append_entries() API returns immediately, which already contains the result of state machine execution. Hence, there will be no later notification.