Refactor: Consolidate directory structure into 5 main categories and update metadata

This commit is contained in:
Antigravity Agent
2026-05-02 23:17:19 +09:00
parent 87fa983521
commit b71a0b82d3
13205 changed files with 114378 additions and 201654 deletions
@@ -1,44 +0,0 @@
---
id: [[P-Reinforce|P-Reinforce]]-AUTO-1BA61A
category: "10_Wiki/💡 Topics/Programming & Language"
confidence_score: 0.90
tags: [auto-reinforced]
last_reinforced: 2026-04-20
github_commit: "[P-Reinforce] Continuous Worker - 관심사의 분리(SoC)"
---
# [[관심사의 분리 (SoC)|관심사의 분리(SoC]]
## 📌 한 줄 통찰 (The Karpathy Summary)
> 관심사의 분리(SoC, [[_뇌와 팔다리의 분리_ - 관심사의 분리 (Separation of Concerns)|Separation of Concerns]])는 소프트웨어 시스템을 각기 다른 기능이나 책임(관심사)에만 집중하는 작고 관리하기 쉬운 독립적인 모듈로 나누는 소프트웨어 엔지니어링의 핵심 설계 원칙이다 [1-5]. 1974년 에츠허르 데이크스트라(Edsger W. Dijkstra)가 처음 제안한 개념으로, 복잡성을 통제하고 코드의 모듈성, 가독성, 유지보수성, 확장성 및 재사용성을 크게 향상시키는 것을 목표로 한다 [3, 4, 6, 7]. 이 철학은 객체 지향 설계의 단일 책임 원칙(SRP)과 인터페이스 분리 원칙(ISP) 등 현대 아키텍처 패턴이 탄생하는 직접적인 근간이 되었다 [5, 8-10].
## 📖 구조화된 지식 (Synthesized Content)
* **원칙의 기원과 진화:**
관심사의 분리라는 용어는 에츠허르 데이크스트라가 1974년 논문 "과학적 사고의 역할에 관하여"에서 '단일 트랙적이면서 동시에 멀티 트랙적인 사고방식'을 통해 복잡한 문제를 고립시켜 집중해야 한다고 주장하면서 등장했다 [11, 12]. 이후 1960~70년대의 구조적 프로그래밍부터 객체 지향 프로그래밍(OOP) 시대를 거쳐 MVC 패러다임, 마이크로서비스 아키텍처(MSA) 등 대규모 시스템을 설계하는 필수 원칙으로 진화해왔다 [8, 10, 13, 14].
* **핵심 메커니즘 (응집도와 결합도):**
SoC를 성공적으로 구현했는지 판단하는 주요 척도는 높은 응집도(High Cohesion)와 낮은 결합도(Low/Loose Coupling)이다 [3, 15-17]. 응집도는 모듈 내부의 요소들이 하나의 명확한 목적을 위해 얼마나 밀접하게 관련되어 있는지를 나타내며, 결합도는 모듈 간의 상호 의존성 정도를 뜻한다 [3, 18, 19]. 좋은 설계는 내부 결속력인 응집도를 극대화하고 외부 간섭에 해당하는 결합도를 최소화하는 최적화를 지향한다 [20, 21].
* **적용 수준과 다양한 사례:**
* **함수 및 모듈 수준:** 각 함수나 모듈은 단일 작업에 집중하도록 분리되어야 한다. 이를 통해 코드가 스파게티처럼 얽히는 것을 방지하고 가독성과 테스트 가능성을 향상시킨다 [22-24].
* **소프트웨어 아키텍처 수준:** 핵심 비즈니스 로직(뇌)과 외부 인프라(팔다리)를 분리하는 것이 핵심이다 [25]. 웹 기반 시스템에서는 프레젠테이션 계층, 비즈니스 로직 계층, 데이터 액세스 계층으로 관심사를 분리하여 의존성이 단방향(주로 내부 핵심 도메인을 향해)으로 흐르도록 설계한다 [21, 26, 27].
* **웹 프론트엔드:** 전통적인 HTML(구조), CSS(표현), [[JavaScript|JavaScript]](동작)의 역할별 분리가 가장 직관적인 SoC 사례이다 [28-30]. 최근에는 프로젝트의 규모가 커짐에 따라 기능(Feature) 단위로 관심사를 묶어 관리하는 FSD([[Feature-Sliced Design|Feature-Sliced Design]]) 방식 등으로 진화하고 있다 [31, 32].
* **로보틱스 제어 시스템:** 로봇 또한 인지적 해부와 동일하게 외부 자극을 감지하는 센서(눈/귀), 의사결정을 내리는 컨트롤러(뇌), 물리적 운동을 수행하는 액추에이터(근육)로 하드웨어적 관심사를 명확히 분리하여 구동된다 [33, 34].
* **주요 이점:**
시스템을 모듈화하면 특정 기능을 수정하거나 확장할 때 다른 코드에 미치는 부작용을 최소화할 수 있어 유지보수성이 크게 향상된다 [35-37]. 여러 명의 개발자가 각기 다른 모듈을 맡아 서로 방해받지 않고 병렬(동시) 개발을 수행할 수 있으며 [35, 38, 39], 비즈니스 로직을 데이터베이스나 UI 등 외부 시스템으로부터 격리시켜 독립적이고 신속한 단위 테스트 환경을 조성할 수 있다 [27, 40, 41].
* **한계 및 실무적 고려사항:**
관심사를 맹목적이고 과도하게 분리(Over-engineering)하면 오히려 계층 간 통신 및 데이터 변환 오버헤드가 증가하여 시스템 성능을 떨어뜨릴 수 있다 [42, 43]. 층을 너무 얇게 나누거나 과도한 추상화를 도입할 경우, 실제 구현을 파악하기 위해 수많은 계층을 넘나들어야 하므로 개발자의 인지적 부하가 오히려 가중될 위험(인디렉션의 저주)이 존재한다 [42, 44, 45].
## ⚠️ 모순 및 업데이트 (Contradictions & RL Update)
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
- **정책 변화:** Programming & Language 분야의 자동 자산화 수행.
## 🔗 지식 연결 (Graph)
- **Related Topics:** [[단일 책임 원칙 (SRP)|단일 책임 원칙(SRP]], 응집도(Cohesion)와 결합도(Coupling), 계층화 아키텍처(Layered Architecture), 모델-뷰-컨트롤러(MVC), [[관점 지향 프로그래밍 (AOP)|관점 지향 프로그래밍(AOP]]
- **Projects/Contexts:** 넷플릭스 코스모스(Cosmos) 플랫폼, 스포티파이 스쿼드(Squad) 및 마이크로 프론트엔드, 화신산(Huoshen Mountain) 병원 모듈러 통합 건설(MiC)
- **Contradictions/Notes:**
* "SoC를 도입하면 유지보수와 모듈성이 향상된다"는 원칙이 일반적이나, "지나친 관심사 분리와 추상화는 간접 참조를 늘리고 런타임 성능 저하 및 코드 추적의 어려움을 유발하여 실무적 복잡성을 오히려 가중시킨다"는 경고와 상충하는 지점이 있다 [42-45].
* 관심사의 선제적인 도출이 필수적이라는 견해가 있는 반면, 다른 실무자들은 초기에 관심사를 미리 예측해 분리하는 것은 불가능에 가까우며, 코드가 중복되어 나타날 때([[Rule of Three|Rule of Three]]) 사후적으로 리팩토링을 통해 분리하는 것(DRY 관점)이 현실적이라는 상반된 주장을 한다 [45, 46].
---
*Last updated: 2026-04-18*
---