Published April 10, 2023 | Version 1.0.1
Conference paper Open

Artifact for Performal: Formal Verification of Latency Properties for Distributed Systems

Creators

Description

Artifact for "Performal: Formal Verification of Latency Properties for Distributed Systems"

Understanding and debugging the performance of distributed systems is a notoriously hard task, but a critical one. Traditional techniques like logging, tracing, and benchmarking represent a best-effort way to find performance bugs, but they either require a full deployment to be effective or can only find bugs after they manifest. Even with such techniques in place, real deployments often exhibit performance bugs that cause unwanted behavior. 

In this paper, we present Performal, a novel methodology that leverages the recent advances in formal verification to provide rigorous latency guarantees for real, complex distributed systems. The task is not an easy one: it requires carefully decoupling the formal proofs from the execution environment, formally defining latency properties, and proving them on real, distributed implementations. We used Performal to prove rigorous upper bounds for the latency of three applications: a distributed lock, ZooKeeper and a MultiPaxos-based State Machine Replication system. Our experimental evaluation shows that these bounds are a good proxy for the behavior of the deployed system and can be used to identify performance bugs in real-world systems. 

Notes

Updated readme from previous version

Files

Files (209.7 MB)

Name Size Download all
md5:73d50e1838ae9d3f0a7ac793791727c1
209.7 MB Download