Context: As the adoption of continuous delivery practices increases in software organizations, different scenarios struggle to make it scales for their products in long-term evolution. This study looks at the concrete software architecture as a relevant factor for successfully achieving continuous delivery goals. Objective: This study aims to understand how the design of software architectures impacts the continuous deployment of their software product. Method: We conducted a systematic literature review to identify proper evidence regarding the research objective. We analyzed the selected sources adopting a synthesis and analysis approach based on Grounded Theory. Results: We selected 14 primary sources. Through our analysis process, we developed a theory that explains the phenomenon of Architecting for Continuous Deployment. The theory describes three other phenomena that support Architecting for Continuous Deployment: Supporting Operations, Continuous Evolution, and Improving Deployability. Furthermore, the theory comprises the following elements: contexts, actions and interactions, quality attributes, principles, and effects. We instantiated these elements and identified their interrelationships. The theory is supported by providing bi-directional traceability from the selected sources to the elements and vice-versa. Conclusions: Developing adequate architecture plays a crucial role in enabling continuous delivery. Supporting operations becomes vital to increase the deployability and monitorability of software architecture. These two outcomes require that developers accept responsibility for maintaining the operations. The continuous evolution of the architecture is essential, but it must consider balanced management of technical debt. Finally, improving deployability requires attention to the test strategy and how it affects downtime to enable efficient pipelines.
翻译:随着软件组织采用连续交付做法的情况增多,不同的假设情景难以使其产品在长期演变中达到规模。本研究将具体软件结构视为成功实现连续交付目标的一个相关因素。目标:本研究旨在了解软件结构的设计如何影响软件产品的连续部署。方法:我们进行了系统的文献审查,以确定与研究目标有关的适当证据。我们分析了选定来源采用基于基层理论的综合和分析方法。结果:我们选择了14个主要来源。我们通过分析进程,形成了一个理论,解释了持续部署的建筑现象。理论描述了支持持续部署建筑的其他三种现象:支持行动、持续演变和改善可部署性。此外,理论包括以下要素:背景、行动和互动、质量属性、原则和影响。我们对这些要素进行了系统化的文献审查,并查明了它们之间的相互关系。理论得到了支持,从选定的来源向各个要素和反之提供双向下向可追溯性跟踪。结论:适当的建筑在持续部署方面发挥着关键作用。支持持续部署结构:支持行动的结构:支持行动、持续演变、持续演变和改进部署能力。此外,理论包括环境、行动、行动、行动和效果的稳定性,这必然需要提高部署的稳定性。