Write a Blog >>
CC 2017
Sun 5 - Mon 6 February 2017 Austin, Texas, United States
Sun 5 Feb 2017 16:00 - 16:30 at 404 - Types

Fault-tolerant communication systems rely on recovery strategies which are often error-prone (e.g.~a programmer manually specifies recovery strategies) or inefficient (e.g.~the whole system is restarted from the beginning). This paper proposes a static analysis based on multiparty session types that can efficiently compute a safe global state from which a system of interacting processes should be recovered. We statically analyse the communication flow of a program, given as a multiparty protocol, to extract the causal dependencies between processes and to localise failures. We formalise our recovery algorithm and prove its safety. A recovered communication system is free from deadlocks, orphan messages and reception errors. Our recovery algorithm incurs less communication cost (only affected processes are notified) and overall execution time (only required states are repeated). On top of our analysis, we design and implement a runtime framework in Erlang where failed processes and their dependencies are soundly restarted from a computed safe state. We evaluate our recovery framework on message-passing benchmarks and a use case for crawling webpages. The experimental results indicate our framework outperforms a built-in static recovery strategy in Erlang when a part of the protocol can be safely recovered.

Sun 5 Feb
Times are displayed in time zone: Saskatchewan, Central America change

15:30 - 16:30: TypesResearch Papers at 404
15:30 - 16:00
Talk
Granullar: Gradual Nullable Types for Java
Research Papers
Dan BrotherstonUniversity of Waterloo, Canada, Werner DietlUniversity of Waterloo, Canada, Ondřej LhotákUniversity of Waterloo, Canada
DOI
16:00 - 16:30
Talk
Let It Recover: Multiparty Protocol-Induced Recovery
Research Papers
Rumyana NeykovaImperial College London, UK, Nobuko YoshidaImperial College London
DOI