Architecture ‐ Modular Monolithic Architecture - dnwls16071/Backend_Study_TIL GitHub Wiki
📚 Modular Monolithic Architecture 개요
- 애플리케이션 로직을 모듈별로 분리
- 각 모듈은 독립적이고 고립적, 자체 기능 캡슐화
- 자체 비즈니스 로직, 데이터베이스 스키마를 가짐
- 코드를 독립적인 모듈로 구분
- 각 모듈은 자체 논리적 분리, 계층적 아키텍처 스타일 또는 clean architecture로 구성
- 모듈은 애플리케이션 도메인의 Bounded Context를 나타냄
- 도메인 컨텍스트 기능을 모듈로 그룹화
- 모듈 간의 종속성을 줄이고 다른 모듈에 영향을 미치지 않고 모듈을 개발하거나 수정 가능
-
장점
- 쉬운 개발 / 디버깅 / 배포
- 비즈니스 로직 캡슐화
- 재사용 가능한 코드, 리팩토링 용이
- 잘 구성된 종속성 및 팀
- 독립적인 프론트엔드 업데이트가 가능(SPA)
-
단점
- 제한적인 확장성, DB 확장 불가
- 병목 현상으로 인한 타임 아웃
- 독립적으로 확장 및 배포 불가
📚 Hexagonal Architecture
- Hexagonal Architecture는 비즈니스 로직을 중심에 위치
- 외부와의 통신은 별도의 Adapter를 통해 처리
- 애플리케이션을 특정 기술, 프레임워크, 인프라에 종속되지 않게 만들어 유연성과 테스트 용이성을 높임
📚 Headless Architecture - SPA
- Frontend - Backend 분리
- UI와 비즈니스 로직 분리
- API를 이용한 애플리케이션 간 통신 -> API를 사용하여 FE와 BE 연결
- FE의 SPA에서 API와 관련된 작업 처리
- SPA
- 반응형 애플리케이션
- 전체 페이지를 다시 로드하지 않고 단일 웹 페이지에 포함된 애플리케이션
- 마이크로서비스 이동 전 단계