클린아키텍처
-
[클린 아키텍처 05] 웹 어댑터 구현하기프로그래밍/기타 2024. 9. 1. 17:20
>우리가 목표로 하는 아키텍처에서 외부 세계와의 모든 커뮤니케이션은 어댑터를 통해 이루어진다! 의존성 역전웹 어댑터는 '주도하는' 어댑터다.외부로부터 요청을 받아 애플리케이션 코어를 호출하고 무슨 일을 해야하는 지 알려준다! 제어흐름adapter.in.web.Controller -> application.port.in.Port application.servcie.Service 애플리케이션 계층은 웹 어댑터가 통신할 수 있는 특정 포트를 제공서비스는 이 포트를 구현하고, 웹 어댑트는 이 포트를 호출할 수 있음 자세히 보면 의존성 역전 원칙이 적용된 걸 볼 수 있음! 왜 어댑터와 유스케이스 사이 또 다른 간접 계층을 넣어야 할까?애플리케이션 코어가 외부 세계와 통신할 수 있는 곳에 대한 명세가 포트이기 때..
-
[클린 아키텍처 04] 유스케이스 구현하기프로그래밍/기타 2024. 8. 26. 23:18
>유스케이스 구현하기유스케이스 둘러보기유스케이스를 구성하는 단계는 다음과 같다. 1. 입력을 받는다2. 비즈니스 규칙을 검증한다.3. 모델 상태를 조작한다.4. 출력을 반환한다. 입력 유효성 검증입력 유효성 검증은 어디에서 해야하는가? 바로 입력 모델이다.input parameter로 들어오는 모델(입력 모델)에서 입력 유효성 검증을 수행한다.해당 모델의 위치는 use case의 위치와 같다! because use case api의 일부이기 때문에! @Value@EqualsAndHashCode(callSuper = false)publicclass SendMoneyCommand extends SelfValidating { @NotNull private final AccountId sourceA..
-
[클린 아키텍처 03] 코드 구성하기프로그래밍/기타 2024. 8. 26. 22:10
>코드 구성하기계층으로 구성하기Web, Domain, Persistence의 구조로 패키지를 구성한다.요렇게 구성하는 경우의 문제점은? 1) 기능이나 특성을 구분짓는 경계가 없음 만약 User 기능이 추가 된다면...?서로 연관되지 않은 기능끼리 마구마구 섞임 (domain 패키지에 user repo, service, user entity 모두 추가됨 ㄷㄷ) 2) 어떤 유스케이스가 있는지 파악 불가AccountController에는 어떤 기능이 있을까..? User Controller에는..?기능으로 구성하기Account 패키지 안에 몽땅 넣는다!그 와중에 AccountService 네이밍을 SendMoneyService로 변경함이렇게 구성할 경우 '송금하기' 기능이 어딨는지 파악 가능하긴 함.. 그러..
-
[클린 아키텍처 02] Dependency Inversion (의존성 역전하기)프로그래밍/기타 2024. 8. 16. 15:34
> 의존성 역전하기백엔드 개발자라면,, 누구나 한번쯤 달달달 외웠을 SOLID 원칙! 그 중 단일 책임 원칙과 의존성 역전 원칙에 대해 자세히 살펴보도록 합시당 단일 책임 원칙우리가 흔히 아는 단일 책임 원칙은 하나의 컴포넌트는 오로지 하나의 역할만을 해야한다는 것이다.그러나 클린 아키텍처의 저자는 단일 책임 원칙을 요로케 표현했당:컴포넌트를 변경하는 이유는 오직 하나뿐이어야 한다. 컴포넌트가 변경되는 이유가 오직 하나 뿐이라면 우리가 다른 이유로 소프트웨어를 변경하더라도 이 친구는 절대 변하지 않는다는 것이다; 요렇게 세 개의 클래스가 있을 때,만약 C가 어떤 함수명을 바꿨다. 그럼 그 친구를 참조하고 있던 A와 B도 어쩔 수 없이 바꿔야함 ㅠ_ㅠ 👎👎👎C는 어느 곳에도 의존하지 않기 때문에 지..
-
[클린 아키텍처 01] What is problem of layered architecture?프로그래밍/기타 2024. 8. 16. 14:05
>'클린 아키텍처' 책 혼자서 가볍게 읽어봤지만 요번에 스터디로도 한번 더 읽게되서겸사겸사 써보는 블로그 ^___^ 코드는 깃헙에 따로 올릴 계획이다 계층형 아키텍처지금 회사 프로젝트에서 쓰고있는 계층형 아키텍처(에서 살짝 변형되긴함)는 가장 보편적으로 많이 사용되는 아키텍처인 것 같다. 개인적으로는 빠른 구현 및 코드 파악하기에는 가장 좋다고 생각함. 한 눈에 들어오잖아요? ㅎ;; 그러나 최근 계층형 아키텍처의 문제점들이 대두되면서 클린 아키텍처, 헥사고날 아키텍처를 선호하는 사람들이 많아졌는데,,그렇다면 계층형 아키텍처의 문제점은 무엇이 있느냐 문제점데이터베이스 중심의 설계위에 그래프에도 보여지듯, 웹은 도메인에 의존하고, 도메인은 영속성에 의존한다 ==> 모든 것이 결국 데이터베이스에 의존하게..