ADR for short.
See Documenting Architecture Decisions for more information.
The basic idea is to capture key decisions having to do with anything architectural in a way that promotes better communication than simple word-of-mouth.
What is an architectural decision? If one or more of the following ideas apply you might be dealing with an architectural decision.
Does the design decision...
- Alter externally visible system properties?
- Modify public interfaces?
- Directly influence high priority quality attributes?
- Include or remove dependencies?
- Result from a discussion where you learned more about technical or business constraints?
- Involve taking on strategic technical debt?
- Change the structures of the system (static, dynamic, or physical)?
- Require other developers to update construction techniques or development environments?
Use this template in any new ADRs. Replace the help text as you write the ADR.
# ADR N: Brief Decision Title
Context goes here.
Describe the forces at play, including technological, political, social, and project local.
These forces are likely in tension, and should be called out as such. The language in this
section is value-neutral. It is simply describing facts.
## Decision
This section describes our response to these forces. It is stated in full sentences,
with active voice. "We will ..."
## Status
choose one: [Proposed | Accepted | Deprecated | Superseded]
if deprecated, include a rationale.
If superseded, include a link to the new ADR
## Consequences
Describe the resulting context, after applying the decision. All consequences should be listed here,
not just the "positive" ones. A particular decision may have positive, negative, and neutral consequences,
but all of them affect the team and project in the future.
- Titles should be descriptive, concise, and precise
- The whole document should be one or two pages long at most.
- Think of the document as a conversation with a future developer. This means write well and use full sentences. Avoid Rambling.
- Update consequences as they become known. The ADR becomes like a diary for seeing how the design decisions we make impact the system over time.
- Include diagrams as necessary. Many decisions don't require diagrams.
Keeling, Michael; Runde, Joe. Architecture Decision Records in Action, from Proceedings of SATURN2017 Conference PDF Video
Keeling, Michael; Runde, Joe. Share the Load: Distribute Design Authority with Architecture Decision Records, from Agile 2018 in San Diego Web Video
Nygard, Michael. Documenting Architecture Decisions, from Think Relevance blog. Web
Kruchten, Philippe. The Decision View's Role in Software Architecture Practice, IEEE Software 26:36-42, February 2009
Tyree, J. and Akerman, A. Architecture Decisions: Demystifying Architecture, IEEE Software 22:2:19-27, March-April 2005 PDF