- Leader election — randomized-timeout election with term and vote safety; one leader per term (live)
- Log replication — batched append-entries with per-follower progress, optimistic pipelining, conflict-hint backtracking, and commit on a quorum (live in v0.3)
- Deterministic core — the state machine is pure and step-driven, so the whole protocol is testable without time or I/O (live)
- Pluggable transport —
RaftTransporttrait; in-memory for tests, real net for production (live) - Pluggable log store —
RaftLogtrait;wal-db-backedWalLogunder thepersistencefeature (live in v0.4) - Crash recovery — term, vote, and log persisted before each RPC; a restarted node recovers and rejoins without violating safety (live in v0.4)
- Snapshotting — install-snapshot for log compaction and fast follower catch-up, driven by a snapshot-policy hint (live in v0.5)
- Typed framing —
pack-iowire encoding for messages under theframingfeature (live in v0.5) - Membership changes — single-server add/remove with safe sequencing, plus leadership transfer (live in v0.6)
Installation
[]
= "0.8"
# Optional features:
= { = "0.8", = ["persistence"] } # durable wal-db-backed `WalLog`
= { = "0.8", = ["framing"] } # pack-io wire framing for messages
Quick Start
A node is a deterministic state machine. You hand it events with step and it
hands back actions to carry out. The single-node path needs nothing else — no
transport, no storage to wire up:
use ;
// One node, no peers: it reaches quorum (itself) the moment it times out.
let mut node = new;
// Drive logical ticks until it elects itself leader.
while !node.is_leader
assert_eq!;
// A leader commits its own proposals immediately (quorum of one).
for action in node.step.unwrap
assert_eq!;
A multi-node cluster works the same way: you route each Action::Send to the
target node's step through a transport of your choosing, and feed every node
logical ticks. The protocol is sans-I/O — when to tick and how to deliver
messages are yours to decide, which is what makes the whole thing testable
without a clock or a network.
Runnable examples show each path end to end:
Status
This is v0.8.0: alpha — feature complete, hardened, in consumer integration.
The full protocol — election (with pre-vote disruption protection), replication,
durable crash recovery, snapshots, membership changes, and leadership transfer — is
in place. A kitchen-sink adversarial test suite drives clusters through combined
partitions, message loss/reorder/duplication, membership churn, and snapshotting,
and asserts all five Raft safety properties (Election Safety, Leader Append-Only,
Log Matching, Leader Completeness, State Machine Safety) continuously over sustained
runs; a companion suite drives a replicated key-value store — the library's first
real consumer — to identical state on every node under the same faults; and the
decode path is fuzzed. The public traits and the wire and WAL formats are frozen
— see the normative docs/PROTOCOL.md;
additions in the 0.x line stay MINOR-compatible (the pre-vote messages are new
#[non_exhaustive] enum variants that change no existing encoding). Beta
and RC hardening follow toward the 1.0 freeze, per the
ROADMAP (development copy). The full
public surface is documented in docs/API.md.
Where It Fits
raft-io is the consensus engine. It is consumed by:
wal-db— durable Raft log persistence (underpersistence)pack-io— typed RPC message framing (underframing)- Hive DB — cluster coordination and replicated metadata
It stays foreign-compatible: usable standalone in any system that needs replicated, fault-tolerant state.
Cross-Platform Support
Tier 1 Support:
- Linux (x86_64, aarch64)
- macOS (x86_64, Apple Silicon)
- Windows (x86_64)
Behavior is verified on each target by the CI matrix.
Contributing
Before opening a PR, cargo fmt --all, cargo clippy --all-targets --all-features -- -D warnings, and cargo test --all-features must be clean. Hot-path changes require a criterion benchmark; correctness-critical paths require property and/or loom tests.