Show simple item record

dc.contributor.authorVera-Rivera, Fredy H.
dc.contributor.authorGaona, Carlos
dc.contributor.authorAstudillo, Hernán
dc.date.accessioned2021-11-26T16:10:41Z
dc.date.available2021-11-26T16:10:41Z
dc.date.issued2018-09-08
dc.identifier.urihttp://repositorio.ufps.edu.co/handle/ufps/1452
dc.description.abstractBackground Microservices are an architectural approach of growing use, and the optimal granularity of a microservice directly affects the application’s quality attributes and usage of computational resources. Determining microservice granularity is an open research topic. Methodology We conducted a systematic literature review to analyze literature that addresses the definition of microservice granularity. We searched in IEEE Xplore, ACM Digital Library and Scopus. The research questions were: Which approaches have been proposed to define microservice granularity and determine the microservices’ size? Which metrics are used to evaluate microservice granularity? Which quality attributes are addressed when researching microservice granularity? Results We found 326 papers and selected 29 after applying inclusion and exclusion criteria. The quality attributes most often addressed are runtime properties (e.g., scalability and performance), not development properties (e.g., maintainability). Most proposed metrics were about the product, both static (coupling, cohesion, complexity, source code) and runtime (performance, and usage of computational resources), and a few were about the development team and process. The most used techniques for defining microservices granularity were machine learning (clustering), semantic similarity, genetic programming, and domain engineering. Most papers were concerned with migration from monoliths to microservices; and a few addressed green-field development, but none address improvement of granularity in existing microservice-based systems. Conclusions Methodologically speaking, microservice granularity research is at a Wild West stage: no standard definition, no clear development—operation trade-offs, and scarce conceptual reuse (e.g., few methods seem applicable or replicable in projects other than their initial proposal). These gaps in granularity research offer clear options to investigate on continuous improvement of the development and operation of microservice-based systems.eng
dc.format.extent47 páginasspa
dc.format.mimetypeapplication/pdfspa
dc.language.isoengspa
dc.publisherPeerJ Computer Sciencespa
dc.relation.ispartofPeerJ Computer Science
dc.rightsPeerJ, Inc. 2012-2021 | Public user content licensed CC BY 4.0 unless otherwise specified.eng
dc.sourcehttps://peerj.com/articles/cs-695/#spa
dc.titleDefining and measuring microservice granularity, a literature overvieweng
dc.typeArtículo de revistaspa
dcterms.referencesAbdullah M, Iqbal W, Erradi A. 2019. Unsupervised learning approach for web application auto-decomposition into microservices. Journal of Systems and Software 151(3):243-257spa
dcterms.referencesAhmadvand M, Ibrahim A. 2016. Requirements reconciliation for scalable and secure microservice (de)composition.spa
dcterms.referencesAl-Debagy O, Martinek P. 2019. A new decomposition method for designing microservices. Periodica Polytechnica Electrical Engineering and Computer Science 63:274-281spa
dcterms.referencesAl-Debagy O, Martinek P. 2020. Extracting microservices’ candidates from monolithic applications: interface analysis and evaluation metrics approach.spa
dcterms.referencesAlipour H, Liu Y. 2017. Online machine learning for cloud resource provisioning of microservice backend systems.spa
dcterms.referencesAstudillo H. 2005. Five ontological levels to describe and evaluate software architectures. Revista Facultad de Ingeniería Universidad de Tarapacá 13(1):69-73spa
dcterms.referencesBaresi L, Garriga M, De Renzis A. 2017. Microservices identification through interface analysis. In: De Paoli F, Schulte S, Broch Johnsen E, eds. Service-Oriented and Cloud Computing. ESOCC 2017. Lecture Notes in Computer Science. Cham: Springer. 10465spa
dcterms.referencesBass L, Clemens P, Katzman R. 1998. Software architecture in practice. Westford, Massachusetts: Addison Wesley.spa
dcterms.referencesBogner J, Wagner S, Zimmermann A. 2017a. Automatically measuring the maintainability of service-and microservice-based systems.spa
dcterms.referencesBogner J, Wagner S, Zimmermann A. 2017b. Towards a practical maintainability quality model for service-and microservice-based systems.spa
dcterms.referencesBouwers E, Correia JP, Van Deursen A, Visser J. 2011. Quantifying the analyzability of software architectures.spa
dcterms.referencesCandela I, Bavota G, Russo B, Oliveto R. 2016. Using cohesion and coupling for software remodularization: is it enough? ACM Transactions on Software Engineering and Methodology 25(3):1-28spa
dcterms.referencesChen R, Li S, Li Z. 2017. From monolith to microservices: a dataflow-driven approach.spa
dcterms.referencesChristoforou A, Odysseos L, Andreou A. 2019. Migration of Software Components to Microservices: Matching and Synthesis.spa
dcterms.referencesCojocaru M, Uta A, Oprescu AM. 2019. MicroValid: a validation framework for automatically decomposed microservices.spa
dcterms.referencesCruz P, Astudillo H, Hilliard R, Collado M. 2019. Assessing migration of a 20-year-old system to a micro-service platform using ATAM.spa
dcterms.referencesDe Alwis AAC, Barros A, Fidge C, Polyvyanyy A. 2019. Business object centric microservices patterns. In: Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics). Springer Nature Switzerland: Springer. 476-495spa
dcterms.referencesDe Alwis AAC, Barros A, Polyvyanyy A, Fidge C. 2018. Function-splitting heuristics for discovery of microservices in enterprise systems.spa
dcterms.referencesDi Francesco P. 2017. Architecting microservices.spa
dcterms.referencesDi Francesco P, Lago P, Malavolta I. 2019. Architecting with microservices: a systematic mapping study. Journal of Systems and Software 150(1):77-97spa
dcterms.referencesGall H, Jazayeri M, Krajewski J. 2003. CVS release history data for detecting logical couplings.spa
dcterms.referencesGhofrani J, Lübke D. 2018. Challenges of microservices architecture: a survey on the state of the practice.spa
dcterms.referencesGouigoux JP, Tamzalit D. 2017. From monolith to microservices: lessons learned on an industrial migration to a web oriented architecture.spa
dcterms.referencesHamzehloui MS, Sahibuddin S, Salah K. 2019. A systematic mapping study on microservices Mohammad. In: Saeed F, Gazem N, Mohammed F, Busalim A, eds. IRICT: International Conference of Reliable Information and Communication Technology 2018. Advances in Intelligent Systems and Computing. Cham: Springer International Publishing.spa
dcterms.referencesHassan S, Bahsoon R. 2016. Microservices and their design trade-offs: a self-adaptive roadmap.spa
dcterms.referencesHassan S, Ali N, Bahsoon R. 2017. Microservice ambients: an architectural meta-modelling approach for microservice granularity.spa
dcterms.referencesHassan S, Bahsoon R, Kazman R. 2020. Microservice transition and its granularity problem: a systematic mapping study. Software: Practice and Experience 50(9):1-31spa
dcterms.referencesvspa
dcterms.referencesHerold S, Klus H, Welsch Y, Deiters C, Rausch A, Reussner R, Krogmann K, Koziolek H, Mirandola R, Hummel B+2 more. 2008. CoCoME - The common component modeling example. In: Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics). Berlin: Springer. 16-53spa
dcterms.referencesHirzalla M, Cleland-Huang J, Arsanjani A. 2009. A metrics suite for evaluating flexibility and complexity in service oriented architectures.spa
dcterms.referencesHomay A, de Sousa M, Zoitl A, Wollschlaeger M. 2020. Service granularity in industrial automation and control systems.spa
dcterms.referencesHomay A, Zoitl A, De Sousa M, Wollschlaeger M, Chrysoulas C. 2019. Granularity cost analysis for function block as a service.spa
dcterms.referencesJamshidi P, Pahl C, Mendonca NC, Lewis J, Tilkov S. 2018. Microservices: the journey so far and challenges ahead. IEEE Software 35(3):24-35spa
dcterms.referencesJin W, Liu T, Cai Y, Kazman R, Mo R, Zheng Q. 2019. Service candidate identification from monolithic systems based on execution traces. IEEE Transactions on Software Engineering 47(5):987-1007spa
dcterms.referencesJosélyne MI, Tuheirwe-Mukasa D, Kanagwa B, Balikuddembe J. 2018. Partitioning microservices - A Domain Engineering Approach.spa
dcterms.referencesKecskemeti G, Marosi AC, Kertesz A. 2016. The ENTICE approach to decompose monolithic services into microservices. In: 2016 International Conference on High Performance Computing and Simulation, HPCS 2016. 591-596spa
dcterms.referencesKecskemeti G, Kertesz A, Marosi AC. 2017. Towards a methodology to form microservices from monolithic ones. In: Euro-Par 2016 Workshops - Lecture Notes in Computer Science. Springer Verlag. 284-295spa
dcterms.referencesKitchenham B. 2004. Procedures for performing systematic reviews.spa
dcterms.referencesKrause A, Zirkelbach C, Hasselbring W, Lenga S, Kroger D. 2020. Microservice decomposition via static and dynamic analysis of the monolith. Proceedings - 2020 IEEE International Conference on Software Architecture Companion, ICSA-C 2020:9-16spa
dcterms.referencesKulkarni N, Dwivedi V. 2008. The role of service granularity in a successful SOA realization—A case study.spa
dcterms.referencesLarman C. 2004. Applying UML and patterns: an introduction to object oriented analysis and design and interative development. (3rd Edition). Prentice Hall PTR, USAspa
dcterms.referencesLi S, Zhang H, Jia Z, Li Z, Zhang C, Li J, Gao Q, Ge J, Shan Z. 2019. A dataflow-driven approach to identifying microservices from monolithic applications. Journal of Systems and Software 157(2):110380spa
dcterms.referencesMa S-P, Chuang Y, Lan C-W, Chen H-M, Huang C-Y, Li C-Y. 2018. Scenario-based microservice retrieval using Word2Vec.spa
dcterms.referencesMancoridis S, Mitchell BS, Rorres C, Chen Y, Gansner ER. 1998. Using automatic clustering to produce high-level system organizations of source code.spa
dcterms.referencesMarquez G, Astudillo H. 2018. Actual use of architectural patterns in microservices-based open source projects.spa
dcterms.referencesMartin RC. 2002. Agile software development principles, patterns, and practices Alan Apt series. Upper Saddle River, NJ: Pearson Education, Inc.spa
dcterms.referencesMazlami G, Cito J, Leitner P. 2017. Extraction of microservices from monolithic software architectures.spa
dcterms.referencesNewman S. 2015. Building microservices. Sebastopol, CA: O’Reilly Media, Inc.spa
dcterms.referencesNunes L, Santos N, Rito Silva A. 2019. From a monolith to a microservices architecture: an approach based on transactional contexts.spa
dcterms.referencesOsses F, Márquez G, Astudillo H. 2018. An exploratory study of academic architectural tactics and patterns in microservices: a systematic literature review.spa
dcterms.referencesPautasso C, Zimmermann O, Amundsen M, Lewis J, Josuttis N. 2017. Microservices in practice, part 1: reality check and service design. IEEE Software 34(1):91-98spa
dcterms.referencesPerepletchikov M, Ryan C, Frampton K. 2007. Cohesion metrics for predicting maintainability of service-oriented software.spa
dcterms.referencesPerepletchikov M, Ryan C, Frampton K, Tari Z. 2007. Coupling metrics for predicting maintainability in service-oriented designs.spa
dcterms.referencesPrachitmutita I, Aittinonmongkol W, Pojjanasuksakul N, Supattatham M, Padungweang P. 2018. Auto-scaling microservices on IaaS under SLA with cost-effective framework.spa
dcterms.referencesRahman MI, Panichella S, Taibi D. 2019. A curated dataset of microservices-based systems.spa
dcterms.referencesRen Z, Wang W, Wu G, Gao C, Chen W, Wei J, Huang T. 2018. Migrating web applications from monolithic structure to microservices architecture.spa
dcterms.referencesRichardson C. 2020. Microservices.io. Microservice architecture pattern.spa
dcterms.referencesRud D, Schmietendorf A, Dumke RR. 2006. Product metrics for service-oriented infrastructures.spa
dcterms.referencesSaidani I, Ouni A, Mkaouer MW, Saied A. 2019. Towards automated microservices extraction using muti-objective evolutionary search.spa
dcterms.referencesSalah T, Jamal Zemerly M, Yeun CY, Al-Qutayri M, Al-Hammadi Y. 2016. The evolution of distributed systems towards microservices architecture.spa
dcterms.referencesSantos N, Salgado CE, Morais F, Melo M, Silva S, Martins R, Pereira M, Rodrigues H, Machado RJ, Ferreira N+1 more. 2019. A logical architecture design method for microservices architectures.spa
dcterms.referencesSchmidt RA, Thiry M. 2020. Microservices identification strategies: a review focused on model-driven engineering and domain driven design approaches.spa
dcterms.referencesShadija D, Rezai M, Hill R. 2017. Microservices: granularity vs. performance.spa
dcterms.referencesSoldani J, Tamburri DA, Van Den Heuvel W-J. 2018. The pains and gains of microservices: a systematic grey literature review. Journal of Systems and Software 146(3):215-232spa
dcterms.referencesTaibi D, Syst K. 2019. From monolithic systems to microservices: a decomposition framework based on process mining.spa
dcterms.referencesTotalmetrics.com. 2020. Total Metrics Approach—Function points.spa
dcterms.referencesTusjunt M, Vatanawood W. 2018. Refactoring orchestrated web services into microservices using decomposition pattern.spa
dcterms.referencesTyszberowicz S, Heinrich R, Liu B, Liu Z. 2018. Identifying microservices using functional decomposition. In: Feng X, Müller-Olm M, Yang Z, eds. International Symposium on Dependable Software Engineering: Theories, Tools, and Applications. Lecture Notes in Computer Science. Cham: Springer International Publishing. 50-65spa
dcterms.referencesVera-Rivera FH. 2018. A development process of enterprise applications with microservices. Encuentro internacional de Ciencias Aplicadas e Ingeniería (Universidad-Industria)—EISI 2018. Journal of Physics: Conference Series 1126:012017spa
dcterms.referencesVera-Rivera FH, Gaona Cuevas CM, Astudillo H. 2019. Desarrollo de aplicaciones basadas en microservicios: tendencias y desafíos de investigación. Revista Ibérica de Sistemas e Tecnologias de Informação E 23:107-120spa
dcterms.referencesVera-Rivera FH, Rojas Morales FA. 2010. Propuesta de aplicación de la Ingeniería del Software Basada en Componentes en el desarrollo de software empresarial. Revista Iteckne 7:128-135spa
dcterms.referencesVillamizar M, Garcés O, Castro H, Verano M, Salamanca L, Gil S. 2015. Evaluating the monolithic and the microservice architecture pattern to deploy web applications in the cloud/Evaluando el Patrón de Arquitectura Monolítica y de Micro Servicios Para Desplegar Aplicaciones en la Nube.spa
dcterms.referencesVural H, Koyuncu M, Guney S. 2017. A systematic literature review on microservices.spa
dcterms.referencesVural H, Koyuncu M, Misra S. 2018. A case study on measuring the size of microservices. In: Laganá A, Gavrilova ML, Kumar V, Mun Y, Tan CJK, Gervasi O, eds. International Conference on Computational Science and Its Applications—ICCSA 2018. Lecture Notes in Computer Science. Berlin, Heidelberg: Springer. 454-463spa
dcterms.referencesWieringa R, Maiden N, Mead N, Rolland C. 2006. Requirements engineering paper classification and evaluation criteria: a proposal and a discussion. Requirements Engineering 11(1):102-107spa
dcterms.referencesZimmermann O. 2017. Microservices tenets: agile approach to service development and deployment. Computer Science—Research and Development 32(3–4):301-310spa
dcterms.referencesZimmermann O, Stocker M, Zdun U, Lübke D, Pautasso C. 2019. Microservice API patterns.spa
dc.identifier.doihttp://dx.doi.org/10.7717/peerj-cs.695
dc.publisher.placeEstados Unidosspa
dc.relation.citationedition(2021)spa
dc.relation.citationendpage47spa
dc.relation.citationissue(2021)spa
dc.relation.citationstartpage1spa
dc.relation.citesVera-Rivera, F. H., Gaona, C., & Astudillo, H. (2021). Defining and measuring microservice granularity—a literature overview. PeerJ Computer Science, 7, e695.
dc.relation.ispartofjournalPeerJ Computer Sciencespa
dc.rights.accessrightsinfo:eu-repo/semantics/openAccessspa
dc.rights.creativecommonsAtribución 4.0 Internacional (CC BY 4.0)spa
dc.subject.proposalMicro service architectureeng
dc.subject.proposalService computingeng
dc.subject.proposalMicro-service granularityeng
dc.subject.proposalMetricseng
dc.subject.proposalMonolith to microserviceseng
dc.subject.proposalMicroservices decompositioneng
dc.subject.proposalQuality attributteseng
dc.subject.proposalSistematic literature revieweng
dc.type.coarhttp://purl.org/coar/resource_type/c_6501spa
dc.type.contentTextspa
dc.type.driverinfo:eu-repo/semantics/articlespa
dc.type.redcolhttp://purl.org/redcol/resource_type/ARTspa
oaire.accessrightshttp://purl.org/coar/access_right/c_abf2spa
oaire.versionhttp://purl.org/coar/version/c_970fb48d4fbd8a85spa
dc.type.versioninfo:eu-repo/semantics/publishedVersionspa


Files in this item

Thumbnail

This item appears in the following Collection(s)

Show simple item record