Publication | Closed Access
MODIST: transparent model checking of unmodified distributed systems
168
Citations
34
References
2009
Year
Unknown Venue
EngineeringVerificationComputer-aided VerificationFault ToleranceModel CheckingFault-tolerant MessagingSoftware AnalysisFormal VerificationDistributed EnvironmentSystems EngineeringTransparent Model CheckingEfficient Error DetectionRuntime VerificationFirst Model CheckerDistributed SystemsComputer ScienceBerkeley DbOperating SystemsDistributed ComputingProgram AnalysisFormal MethodsSystem Software
MODIST is the first model checker designed for transparently checking unmodified distributed systems running on unmodified operating systems. It achieves this transparency via a novel architecture: a thin interposition layer exposes all actions in a distributed system and a centralized, OS-independent model checking engine explores these actions systematically. We made MODIST practical through three techniques: an execution engine to simulate consistent, deterministic executions and failures; a virtual clock mechanism to avoid false positives and false negatives; and a state exploration framework to incorporate heuristics for efficient error detection. We implemented MODIST on Windows and applied it to three well-tested distributed systems: Berkeley DB, a widely used open source database; MPS, a deployed Paxos implementation; and PACIFICA, a primary-backup replication protocol implementation. MODIST found 35 bugs in total. Most importantly, it found protocol-level bugs (i.e., flaws in the core distributed protocols) in every system checked: 10 in total, including 2 in Berkeley DB, 2 in MPS, and 6 in PACIFICA.
| Year | Citations | |
|---|---|---|
Page 1
Page 1