SEDCApr 28, 2020

Modeling the Raft Distributed Consensus Protocol in LNT

arXiv:2004.13284v16 citations
Originality Synthesis-oriented
AI Analysis

This work is incremental, providing insights for researchers and practitioners in formal methods and distributed systems by refining existing specifications and tools.

The paper tackled the problem of modeling the Raft distributed consensus protocol in the LNT process algebra, finding and correcting issues in the original TLA+ specification, and used this exercise to discuss best practices for using LNT and CADP tools in protocol modeling.

Consensus protocols are crucial for reliable distributed systems as they let them cope with network and server failures. For decades, most consensus protocols have been designed as variations of the seminal Paxos, yet in 2014 Raft was presented as a new, "understandable" protocol, meant to be easier to implement than the notoriously subtle Paxos family. Raft has since been used in various industrial projects, e.g. Hashicorp's Consul or etcd (used by Google's Kubernetes). The correctness of Raft is established via a manual proof, based on a TLA+ specification of the protocol. This paper reports our experience in modeling Raft in the LNT process algebra. We found a couple of issues with the original TLA+ specification of Raft, which has been corrected since. More generally, this exercise offers a great opportunity to discuss how to best use the features of the LNT formal language and the associated CADP verification toolbox to model distributed protocols, including network and server failures.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes