Determining Microservice Boundaries: A Case Study Using Static and Dynamic Software Analysis

Tiago Matias,Filipe F. Correia,Jonas Fritzsch,Justus Bogner,Hugo S. Ferreira,André Restivo
DOI: https://doi.org/10.48550/arXiv.2007.05948
2020-07-12
Abstract:A number of approaches have been proposed to identify service boundaries when decomposing a monolith to microservices. However, only a few use systematic methods and have been demonstrated with replicable empirical studies. We describe a systematic approach for refactoring systems to microservice architectures that uses static analysis to determine the system's structure and dynamic analysis to understand its actual behavior. A prototype of a tool was built using this approach (MonoBreaker) and was used to conduct a case study on a real-world software project. The goal was to assess the feasibility and benefits of a systematic approach to decomposition that combines static and dynamic analysis. The three study participants regarded as positive the decomposition proposed by our tool, and considered that it showed improvements over approaches that rely only on static analysis.
Software Engineering,Distributed, Parallel, and Cluster Computing
What problem does this paper attempt to address?