Item request has been placed! ×
Item request cannot be made. ×
loading  Processing Request

Model Checking Distributed Protocols in Must

Item request has been placed! ×
Item request cannot be made. ×
loading   Processing Request
  • Additional Information
    • Publication Information:
      Association for Computing Machinery
    • Publication Date:
      2024
    • Collection:
      ETH Zürich Research Collection
    • Abstract:
      We describe the design and implementation of Must, a framework for modeling and automatically verifying distributed systems. Must provides a concurrency API that supports multiple communication models, on top of a mainstream programming language, such as Rust. Given a program using this API, Must verifies it by means of a novel, optimal dynamic partial order reduction algorithm that maintains completeness and optimality for all communication models supported by the API. We use Must to design and verify models of distributed systems in an industrial context. We demonstrate the usability of Must’s API by modeling high-level system idioms (e.g., timeouts, leader election, versioning) as abstractions over the core API, and demonstrate Must’s scalability by verifying systems employed in production (e.g., replicated logs, distributed transaction management protocols), the verification of which lies beyond the capacity of previous model checkers. ; ISSN:2475-1421
    • File Description:
      application/application/pdf
    • Relation:
      info:eu-repo/semantics/altIdentifier/wos/001360845100025; http://hdl.handle.net/20.500.11850/703806
    • Accession Number:
      10.3929/ethz-b-000703806
    • Online Access:
      https://hdl.handle.net/20.500.11850/703806
      https://doi.org/10.3929/ethz-b-000703806
    • Rights:
      info:eu-repo/semantics/openAccess ; http://creativecommons.org/licenses/by/4.0/ ; Creative Commons Attribution 4.0 International
    • Accession Number:
      edsbas.73EBBCAB