No Cover Image

Journal article 24454 views 698 downloads

Software sustainability: Research and practice from a software architecture viewpoint

Colin C. Venters, Rafael Capilla, Stefanie Betz, Birgit Penzenstadler, Tom Crick Orcid Logo, Steve Crouch, Elisa Yumi Nakagawa, Christoph Becker, Carlos Carrillo

Journal of Systems and Software, Volume: 138, Pages: 174 - 188

Swansea University Author: Tom Crick Orcid Logo

Abstract

ContextModern societies are highly dependent on complex, large-scale, software-intensive systems that increasingly operate within an environment of continuous availability, which is challenging to maintain and evolve in response to the inevitable changes in stakeholder goals and requirements of the...

Full description

Published in: Journal of Systems and Software
ISSN: 01641212
Published: Elsevier 2018
Online Access: Check full text

URI: https://cronfa.swan.ac.uk/Record/cronfa43519
Tags: Add Tag
No Tags, Be the first to tag this record!
Abstract: ContextModern societies are highly dependent on complex, large-scale, software-intensive systems that increasingly operate within an environment of continuous availability, which is challenging to maintain and evolve in response to the inevitable changes in stakeholder goals and requirements of the system. Software architectures are the foundation of any software system and provide a mechanism for reasoning about core software quality requirements. Their sustainability – the capacity to endure in changing environments – is a critical concern for software architecture research and practice.ProblemAccidental software complexity accrues both naturally and gradually over time as part of the overall software design and development process. From a software architecture perspective, this allows several issues to overlap including, but not limited to: the accumulation of technical debt design decisions of individual components and systems leading to coupling and cohesion issues; the application of tacit architectural knowledge resulting in unsystematic and undocumented design decisions; architectural knowledge vaporisation of design choices and the continued ability of the organization to understand the architecture of its systems; sustainability debt and the broader cumulative effects of flawed architectural design choices over time resulting in code smells, architectural brittleness, erosion, and drift, which ultimately lead to decay and software death. Sustainable software architectures are required to evolve over the entire lifecycle of the system from initial design inception to end-of-life to achieve efficient and effective maintenance and evolutionary change.MethodThis article outlines general principles and perspectives on sustainability with regards to software systems to provide a context and terminology for framing the discourse on software architectures and sustainability. Focusing on the capacity of software architectures and architectural design choices to endure over time, it highlights some of the recent research trends and approaches with regards to explicitly addressing sustainability in the context of software architectures.ContributionThe principal aim of this article is to provide a foundation and roadmap of emerging research themes in the area of sustainable software architectures highlighting recent trends, and open issues and research challenges.
Keywords: Software architecture, Software sustainability, Longevity, Evolution
College: Faculty of Humanities and Social Sciences
Start Page: 174
End Page: 188