4.6 Article

D2ABS: A Framework for Dynamic Dependence Analysis of Distributed Programs

Journal

IEEE TRANSACTIONS ON SOFTWARE ENGINEERING
Volume 48, Issue 12, Pages 4733-4761

Publisher

IEEE COMPUTER SOC
DOI: 10.1109/TSE.2021.3124795

Keywords

Distributed system; program analysis; dependence analysis; dynamic analysis

Funding

  1. U.S. National Science Foundation(NSF) [CCF-1936522]
  2. U.S. Department ofEnergy (DOE) [379101]

Ask authors/readers for more resources

This paper presents the D(2)ABS framework for dynamic dependence analysis of distributed programs, offering a trade-off between efficiency and precision. By ordering events and utilizing message-passing semantics, the framework can compute method-level dependencies across different processes.
As modern software systems are increasingly developed for running in distributed environments, it is crucial to provide fundamental techniques such as dependence analysis for checking, diagnosing, and evolving those systems. However, traditional dependence analysis is either inapplicable or of very limited utility for distributed programs due to the decoupled components of these programs which run in concurrent processes at physically separated machines. Motivated by the need for dependence analysis of distributed software and the diverse cost-effectiveness needs of dependence-based applications, this paper presents D(2)ABS, a framework of dynamic dependence analysis for distributed programs. By partially ordering distributed method execution events and inferring causality from the ordered events, D(2)ABS computes method-level dependencies both within and across process boundaries. Further, by exploiting message-passing semantics across processes, and incorporating static dependencies and statement coverage within individual components, D(2)ABS offers three additional instantiations that trade efficiency for better precision. We present the design of the D(2)ABS framework and evaluate the four instantiations of D(2)ABS on distributed systems of various architectures and scales using our implementation for Java. Our empirical results show that D(2)ABS is significantly more effective than existing options while offering varying levels of cost-effectiveness tradeoffs. As our framework essentially computes whole-system run-time dependencies, it naturally empowers a range of other dependence-based applications.

Authors

I am an author on this paper
Click your name to claim this paper and add it to your profile.

Reviews

Primary Rating

4.6
Not enough ratings

Secondary Ratings

Novelty
-
Significance
-
Scientific rigor
-
Rate this paper

Recommended

No Data Available
No Data Available