Jump to content

List of system quality attributes

From Wikipedia, the free encyclopedia

Within systems engineering, quality attributes are realized non-functional requirements used to evaluate the performance of a system. These are sometimes named architecture characteristics, or "ilities" after the suffix many of the words share. They are usually architecturally significant requirements that require architects' attention.[1]

In software architecture, these attributed are known as "architectural characteristic" or non-functional requirements. Note that it's software architects' responsibility to match these attributes with business requirements and user requirements. Note that synchronous communication between software architectural components, entangles them and they must share the same architectural characteristics. [2]

Quality attributes[edit]

Notable quality attributes include:

Many of these quality attributes can also be applied to data quality.

Common subsets[edit]

  • Together, reliability, availability, serviceability, usability and installability, are referred to as RASUI.
  • Functionality, usability, reliability, performance and supportability are together referred to as FURPS in relation to software requirements.
  • Agility in working software is an aggregation of seven architecturally sensitive attributes: debuggability, extensibility, portability, scalability, securability, testability and understandability.
  • For databases reliability, availability, scalability and recoverability (RASR), is an important concept.
  • Atomicity, consistency, isolation (sometimes integrity), durability (ACID) is a transaction metric.
  • When dealing with safety-critical systems, the acronym reliability, availability, maintainability and safety (RAMS) is frequently used.[citation needed]
  • Dependability is an aggregate of availability, reliability, safety, integrity and maintainability.
    • Integrity depends on security and survivability.
    • Security is a composite of confidentiality, integrity and availability. Security and dependability are often treated together.

See also[edit]

References[edit]

  1. ^ Chen, Lianping (2013). "Characterizing Architecturally Significant Requirements" (PDF). IEEE Software. 30 (2): 38–45. doi:10.1109/MS.2012.174. hdl:10344/3061. S2CID 17399565.
  2. ^ Fundamentals of Software Architecture: An Engineering Approach. 2020. ISBN 978-1492043454.

Further reading[edit]