Architecture ‐ Modular Monolithic Architecture - dnwls16071/Backend_Study_TIL GitHub Wiki

📚 Modular Monolithic Architecture 개요

  • 애플리케이션 로직을 모듈별로 분리
    • 각 모듈은 독립적이고 고립적, 자체 기능 캡슐화
    • 자체 비즈니스 로직, 데이터베이스 스키마를 가짐
    • 코드를 독립적인 모듈로 구분
  • 각 모듈은 자체 논리적 분리, 계층적 아키텍처 스타일 또는 clean architecture로 구성
    • 모듈은 애플리케이션 도메인의 Bounded Context를 나타냄
    • 도메인 컨텍스트 기능을 모듈로 그룹화
  • 모듈 간의 종속성을 줄이고 다른 모듈에 영향을 미치지 않고 모듈을 개발하거나 수정 가능

  • 장점

    • 쉬운 개발 / 디버깅 / 배포
    • 비즈니스 로직 캡슐화
    • 재사용 가능한 코드, 리팩토링 용이
    • 잘 구성된 종속성 및 팀
    • 독립적인 프론트엔드 업데이트가 가능(SPA)
  • 단점

    • 제한적인 확장성, DB 확장 불가
    • 병목 현상으로 인한 타임 아웃
    • 독립적으로 확장 및 배포 불가

📚 Hexagonal Architecture

image

  • Hexagonal Architecture는 비즈니스 로직을 중심에 위치
  • 외부와의 통신은 별도의 Adapter를 통해 처리
  • 애플리케이션을 특정 기술, 프레임워크, 인프라에 종속되지 않게 만들어 유연성과 테스트 용이성을 높임

📚 Headless Architecture - SPA

  • Frontend - Backend 분리
    • UI와 비즈니스 로직 분리
    • API를 이용한 애플리케이션 간 통신 -> API를 사용하여 FE와 BE 연결
    • FE의 SPA에서 API와 관련된 작업 처리
  • SPA
    • 반응형 애플리케이션
    • 전체 페이지를 다시 로드하지 않고 단일 웹 페이지에 포함된 애플리케이션
  • 마이크로서비스 이동 전 단계