넘치게 채우기

5-12. 메인(Main) 컴포넌트 본문

개발/Clean Architecture

5-12. 메인(Main) 컴포넌트

riveroverflow 2023. 12. 20. 11:25
728x90
반응형

모든 시스템에는 최소한 하나의 컴포넌트가 존재하고, 이 컴포넌트가 나머지 컴포넌트를 생성하고, 조정하며, 관리한다. 이 컴포넌트를 밥 아저씨는 메인(Main)이라고 부른다.

 

궁극적인 세부사항

메인 컴포넌트는 궁극적인 세부사항으로, 가장 낮은 수준의 정책이다.

메인은 시스템의 초기 진입점이다.

운영체제를 제외하면 어떤 것도 메인에 의존하지 않는다.

 

메인은 모든 팩토리와 전략, 그리고 시스템 전반을 담당하는 부분으로, 제어권을 넘기는 역할을 맡는다.

의존성 주입 프레임워크를 이용해 의존성을 주입하는 일은 바로 이 메인 컴포넌트에서 이뤄져야 한다. 메인에 의존성이 일단 주입되고 나면, 메인은 의존성 주입 프레임워크를 사용하지 않고도 일반적인 방식으로 의존성을 분배할 수 있어야 한다.

메인을 지저분한 컴포넌트 중에서도 가장 지저분한 컴포넌트라고 생각하자.

 

(Hunt the wumpus예시는 생략)

 

메인은 클린 아키텍처에서 가장 바깥 원에 위치하는, 지저분한 저수준 모듈이라는 점이다. 메인은 고수준의 시스템을 위한 모든 것을 로드한 후, 제어권을 고수준의 시스템에게 넘긴다.

 

결론

메인을 애플리케이션의 플러그인이라고 생각하자.

메인은 초기 조건과 설정을 구성하고, 외부 자원을 모두 수집한 후, 제어권을 애플리케이션의 고수준 정책으로 넘기는 플러그인이다.

메인은 플러그인이므로 메인 컴포넌트를 애플리케이션의 설정별로 하나씩 두도록 하여 둘 이상의 메인 컴포넌트를 만들 수도 있다.

 

예를 들어 개발용 메인 플러그인, 별도의 테스트용 메인 플러그인, 그리고 또 다른 상용 메인 플러그인을 만들 수 있다.

또한 배포하려는 국가별로, 관할 영역별로, 고객별로 메인 플러그인을 만들 수도 있다.

 

메인을 플러그인 컴포넌트로 여기고, 그래서 아키텍처 경계 바깥에 위치한다고 보면 설정 관련 문제를 훨씬 쉽게 해결할 수 있다.

728x90
반응형

'개발 > Clean Architecture' 카테고리의 다른 글

5-14. 테스트 경계  (0) 2023.12.22
5-13. '크고 작은 모든' 서비스들  (0) 2023.12.21
5-11. 계층과 경계  (0) 2023.12.19
5-10. 부분적 경계  (0) 2023.12.18
5-9. 프레젠터와 험블 객체  (0) 2023.12.17