"매 software architecture = 4 zoom levels (Context → Container → Component → Code).". 매 Simon Brown 이 2006년경 제안한 lightweight visualization framework. 매 2026 현재 Structurizr DSL + Mermaid C4 plugin 으로 diagram-as-code 가 standard, 매 audience-specific abstraction level 이 핵심 가치.
매 핵심
매 4 levels
L1 — System Context: 매 system + users + external systems. 매 non-technical stakeholder 용.
L2 — Container: 매 deployable unit (web app, API, DB, queue). 매 technical lead 용.
L3 — Component: 매 container 내부 logical grouping (controller, service, repo). 매 dev team 용.
L4 — Code: 매 class diagram (UML). 매 거의 안 그림 — IDE 가 대신.
매 supplementary diagrams
Deployment diagram: 매 container → infrastructure node mapping.
Dynamic diagram: 매 runtime sequence/collaboration.
System landscape: 매 enterprise-wide multi-system view.
매 응용
Onboarding doc: 매 새 dev 의 codebase orientation.
ADR illustration: 매 architecture decision record 의 visual aid.
Stakeholder communication: 매 PM/exec 에게 system scope 설명.
Compliance audit: 매 data flow / boundary 시각화.
💻 패턴
Structurizr DSL (canonical)
workspace "Banking System" {
model {
customer = person "Customer"
bankSystem = softwareSystem "Internet Banking" {
webApp = container "Web Application" "Spring Boot" "Java"
mobileApp = container "Mobile App" "React Native" "TypeScript"
api = container "API" "Spring Boot" "Java"
db = container "Database" "PostgreSQL" "RDBMS"
webApp -> api "uses" "JSON/HTTPS"
mobileApp -> api "uses" "JSON/HTTPS"
api -> db "reads/writes" "JDBC"
}
mainframe = softwareSystem "Mainframe" "External"
customer -> bankSystem "uses"
bankSystem -> mainframe "fetches account data" "MQ"
}
views {
systemContext bankSystem { include * autolayout }
container bankSystem { include * autolayout }
theme default
}
}
Mermaid C4 (in-repo markdown)
C4Context
title System Context — Banking
Person(customer, "Customer")
System(bank, "Internet Banking", "Allows customers to view accounts")
System_Ext(mainframe, "Mainframe", "Legacy core banking")
Rel(customer, bank, "Uses")
Rel(bank, mainframe, "Fetches data", "MQ")
# CI step — render diagrams from DSL
docker run --rm -v $PWD:/usr/local/structurizr structurizr/cli \
export -workspace workspace.dsl -format plantuml/c4plantuml
plantuml -tsvg *.puml
mv *.svg docs/architecture/
ADR + C4 link
# ADR-007: Move auth to dedicated service
**Status**: Accepted
**Context**: See [Container diagram](../diagrams/banking-containers.svg)
**Decision**: Extract `authService` component into its own container.
**Consequences**: New diagram in `diagrams/v2-containers.svg`.