A proposed catalog of development patterns for fault-tolerant microservices
Resumo
The microservices architecture enables software to be composed of small, independent services that communicate using well-defined APIs. Microservices promote scalability and agility in application development, accelerating the time-to-market for new features. While this model has gained prominence in the industry, there are challenges in understanding the intricacies of this architecture compared to monolithic systems, defining test scenarios focused on resilience, lacking a testing process tailored to the inherent challenges of this architecture, and classifying solutions that can be adopted proactively to avoid inconsistencies and resource unavailability. This work presents an initial catalog of patterns for developing fault-tolerant microservices. A literature review and an industry survey were conducted to classify the difficulties, strategies, and solutions contributing to developing resilient microservices. The study involved 23 highly experienced software engineers in this field. The results suggest a widespread difficulty in developing fault-tolerant microservices and defining a quality criterion. In this regard, the proposed classification can contribute to defining quality requirements and verification strategies.
Palavras-chave:
Microservices, Fault-tolerance, Catalog
Publicado
05/11/2024
Como Citar
MIRANDA, Fábio de Souza; SANTOS, Daniel Saavedra dos; VILELA, Ricardo Ferreira; ASSUNÇÃO, Wesley Klewerton Guez; SANTOS, Reginaldo Cordeiro dos; PINTO, Victor Hugo Santiago Costa.
A proposed catalog of development patterns for fault-tolerant microservices. In: SIMPÓSIO BRASILEIRO DE QUALIDADE DE SOFTWARE (SBQS), 23. , 2024, Bahia/BA.
Anais [...].
Porto Alegre: Sociedade Brasileira de Computação,
2024
.
p. 406–416.