Utilize este identificador para referenciar este registo:
http://hdl.handle.net/10362/142220
Título: | Robust Contract Evolution in a TypeSafe MicroService Architectures |
Autor: | Seco, João Costa Ferreira, Paulo Lourenço, Hugo Ferreira, Carla Ferrão, Lúcio |
Palavras-chave: | microservices service compatibility software evolution type safety Artificial Intelligence Computational Theory and Mathematics Software Theoretical Computer Science Modelling and Simulation |
Data: | 2020 |
Citação: | Seco, J. C., Ferreira, P., Lourenço, H., Ferreira, C., & Ferrão, L. (2020). Robust Contract Evolution in a TypeSafe MicroService Architectures. Art, Science, and Engineering of Programming, 4(3), Article 10. https://doi.org/10.22152/programming-journal.org/2020/4/10 |
Resumo: | Microservice architectures allow for short deployment cycles and immediate effects, but offer no safety mechanisms for service contracts when they need to be changed. Maintaining the soundness of microservice architectures is an error-prone task that is only accessible to the most disciplined development teams. The strategy to evolve a producer service without disrupting its consumers is often to maintain multiple versions of the same interface and dealing with an explicitly managed handoff period and its inherent disadvantages. We present a microservice management system that statically verifies service interface signatures against their references and supports the seamless evolution of compatible interfaces. We define a compatibility relationon types that captures real evolution patterns and embodies known good practices on the evolution of interfaces. Namely, we allow for addition, removal, and renaming of data fields of a producer module without breaking or needing to upgrade consumer services. The evolution of interfaces is supported by runtime generated proxy components that dynamically adapt data exchanged between services to match with the statically checked service code. The model proposed in this paper is instantiated in a core programming language whose semantics is defined by a labelled transition system and a type system that prevents breaking changes from being deployed. Standard soundness results for the core language entail the existence of adapters, and hence ensure the absence of adaptation errors and the correctness of the management model. This adaptive approach allows for gradual deployment of modules, without halting the whole system and avoiding losing or misinterpreting data exchanged between system nodes. Experimental data shows that an average of 57% of deployments that would require adaptation and recompilation are safe under our approach. |
Descrição: | This work was partially supported by FCT/MCTES grant PTDC/EEICTP/4293/2014. Publisher Copyright: © João Costa Seco, Paulo Ferreira, Hugo Lourenço, Carla Ferreira, and Lúcio Ferrão. |
Peer review: | yes |
URI: | http://hdl.handle.net/10362/142220 |
DOI: | https://doi.org/10.22152/programming-journal.org/2020/4/10 |
ISSN: | 2473-7321 |
Aparece nas colecções: | Home collection (FCT) |
Ficheiros deste registo:
Ficheiro | Descrição | Tamanho | Formato | |
---|---|---|---|---|
2002.06185.pdf | 334,06 kB | Adobe PDF | Ver/Abrir |
Todos os registos no repositório estão protegidos por leis de copyright, com todos os direitos reservados.