Software Architecture: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
No edit summary
 
(One intermediate revision by the same user not shown)
Line 25: Line 25:
* [[Eventually Consistent Systems]]
* [[Eventually Consistent Systems]]
* [https://martinfowler.com/bliki/FluentInterface.html Fluent Interface]
* [https://martinfowler.com/bliki/FluentInterface.html Fluent Interface]
* [[Universal Scalability Law]], [[Amdahl Law]]
* [[Universal Scalability Law]], [[Amdahl's Law]]
* [[Domain-Driven Design]]
* [[Domain-Driven Design]]
* [[Single Page Application (SPA)]]
* [[Single Page Application (SPA)]]
Line 64: Line 64:
===Connascence===
===Connascence===
{{Internal|Connascence|Connascence}}
{{Internal|Connascence|Connascence}}
===Bounded Context===


=Organizatorium=
=Organizatorium=

Latest revision as of 04:16, 31 December 2023

External

Internal

Overview

The art of software architecture belongs under the larger domain of software engineering, alongside software development.

Subjects

Concepts

Software Architecture

Evolutionary Software Architecture

Evolutionary software architecture is the sum of software engineering practices and techniques, as well as structural architectural patterns that allow incremental guided change across multiple dimensions of a software system. The dimensions in question include first and foremost the domain, but also multiple other architectural characteristics the system designers deem as important.

Requirements

Functional requirements (related to domain) and non-functional requirements, associated to architectural characteristics.

Domain

Architectural Characteristics

Framework

Platform

Architectural Governance

Definition. TO DO.

Architectural governance includes code reviews, architecture review boards (manual, bureaucracy).

Change

Incremental change.

Architectural Patterns

Coupling and Cohesion

Referred by:

Connascence

Connascence

Bounded Context

Organizatorium

TODO