58 lines
9.1 KiB
Markdown
58 lines
9.1 KiB
Markdown
# [[Microservices Architecture (MSA)]]
|
|
|
|
## 📌 Brief Summary
|
|
마이크로서비스 아키텍처(MSA)는 애플리케이션을 비즈니스 역량 중심으로 세분화하여 조직하고, 독립적으로 배포 및 실행이 가능한 작은 서비스들의 조합으로 시스템을 구축하는 아키텍처 스타일입니다 [1, 2]. "한 가지 일을 잘 수행하는 것(Do one thing and do it well)"이라는 유닉스 철학을 따르며, 대규모 분산 환경에서 부하와 트래픽 스파이크를 우아하게 처리하고 시스템의 회복력(Resiliency)을 높일 목적으로 도입됩니다 [1, 2]. 개별 서비스들은 프레임워크나 언어에 종속되지 않고 HTTP나 경량화된 메시징 프로토콜을 통해 통신하여 조직의 민첩한 개발 및 배포를 지원합니다 [2, 3].
|
|
|
|
## 📖 Core Content
|
|
* **구성 및 특성**: MSA는 분산된 거버넌스와 데이터 관리를 특징으로 하며, 똑똑한 엔드포인트와 단순한 파이프(Smart endpoints and dumb pipes), 실패를 가정한 설계(Design for failure) 및 진화형 설계 철학을 근간으로 합니다 [2]. 프로젝트 단위가 아닌 제품 단위로 팀을 구성하며, 서비스들이 각기 다른 프레임워크나 언어로 작성되더라도 무방하도록 설계됩니다 [2, 3].
|
|
* **프레임워크 기반의 구현 패턴 (프레임워크별 실전 패턴)**:
|
|
* **Spring Boot & Spring Cloud**: Java 생태계에서는 분산 시스템 개발의 보일러플레이트 패턴(환경 설정 관리, 서비스 디스커버리, 서킷 브레이커, 지능형 라우팅)을 빠르게 구축하기 위해 Spring Cloud와 Netflix OSS(Eureka, Hystrix, Zuul, Ribbon 등)를 널리 활용합니다 [4, 5].
|
|
* **NestJS**: TypeScript와 Node.js 기반의 NestJS는 모듈화된 아키텍처를 바탕으로 TCP, Redis, Kafka, RabbitMQ, gRPC 등 다중 트랜스포트를 지원하는 내장 마이크로서비스 기능을 제공하여 견고한 서비스 간 통신 패턴을 강제합니다 [6, 7].
|
|
* **대규모 모니터링과 분석**: 수많은 마이크로서비스 간의 상호작용 속에서 병목 현상을 파악하기 위해, 넷플릭스(Netflix)는 요청 흐름을 시각화하는 Slalom, 수만 개의 메트릭에서 문제를 축소하는 Mogul, 인스턴스 성능을 고해상도로 모니터링하는 Vector 등 거시적/미시적 관점의 텔레메트리 도구를 구축하여 시스템 성능을 관리합니다 [8-11].
|
|
|
|
## ⚖️ Trade-offs & Caveats
|
|
* **복잡성의 이동과 경계 분할의 어려움**: 컴포넌트의 경계를 깔끔하게 정의하지 못할 경우, 단일 시스템 내부에 있던 복잡성이 서비스 간의 네트워크 연결부로 이동하여 오히려 시스템을 약화시킬 위험이 있습니다 [12]. "약한 팀은 항상 약한 시스템을 만든다"는 사실을 주의해야 합니다 [12].
|
|
* **운영 및 디버깅의 고도화**: 단일 모놀리스 환경에 비해 디버깅, 배포, 로깅의 난이도가 기하급수적으로 상승합니다 [13]. 횡단 관심사(캐싱, 보안, 인증, 에러 처리, 동시성 제어 등)를 모든 분산 서비스에 걸쳐 일관되게 적용하는 별도의 전략이 요구됩니다 [14-17].
|
|
* **성능 및 통신 병목**: 동기식 HTTP 프로토콜은 트래픽이 많은 시스템에서 제한 요소가 될 수 있으므로, 비동기 메시징 기반이나 자동 백프레셔(Back pressure)를 활용한 논블로킹 통신 방식의 고려가 필수적입니다 [13].
|
|
* **아키텍처 도입 시점**: 20명 미만의 개발자 팀일 경우 처음부터 MSA를 시작하는 것은 권장되지 않습니다 [13]. 마틴 파울러는 "모놀리스로 시작하여 모듈식으로 유지하다가, 모놀리스가 문제가 될 때 마이크로서비스로 분할하라"고 권장합니다 [18].
|
|
|
|
## 🔗 Knowledge Connections
|
|
|
|
### Related Concepts
|
|
|
|
#### [아키텍처 설계 및 진화 (Architecture Design & Evolution)]
|
|
* [[Monolithic Architecture]]
|
|
* 연결 이유: 마이크로서비스 아키텍처의 출발점이자, 프로젝트 초기에 권장되는 아키텍처이기 때문입니다 [18].
|
|
* 이 개념을 통해 더 깊게 이해할 수 있는 부분: 초기 시스템의 디버깅 및 배포 효율성, 그리고 어느 시점에 시스템의 모듈을 마이크로서비스로 분리해야 하는지에 대한 아키텍처적 진화 과정을 깊이 이해할 수 있습니다 [13, 18].
|
|
* [[Cross-Cutting Concerns]]
|
|
* 연결 이유: MSA와 같은 분산 시스템에서는 로깅, 보안, 에러 처리, 분산 캐싱 등의 공통 로직(횡단 관심사)을 모든 서비스 전반에 걸쳐 일관되게 관리해야 하기 때문입니다 [14, 17, 19].
|
|
* 이 개념을 통해 더 깊게 이해할 수 있는 부분: 분산 시스템의 무결성을 보장하고 파편화된 서비스 관리 복잡성을 줄이기 위해 AOP, 미들웨어, 인터셉터와 같은 프레임워크 패턴을 어떻게 활용해야 하는지 알 수 있습니다 [19-22].
|
|
|
|
#### [구현 생태계 및 도구 (Implementation Ecosystem & Tools)]
|
|
* [[Spring Cloud Netflix]]
|
|
* 연결 이유: Spring Boot 환경에서 Eureka(서비스 디스커버리), Hystrix(서킷 브레이커) 등의 Netflix 오픈소스를 결합하여 MSA 패턴을 쉽게 구축하게 돕는 핵심 도구이기 때문입니다 [4, 5].
|
|
* 이 개념을 통해 더 깊게 이해할 수 있는 부분: 엔터프라이즈 레벨의 분산 시스템에서 로드 밸런싱, 장애 격리(Fault Tolerance), 서비스 등록 및 탐색 등의 기술적 복잡성을 프레임워크 수준에서 어떻게 해결하는지 이해할 수 있습니다 [4, 5, 18].
|
|
* [[NestJS Microservices]]
|
|
* 연결 이유: Node.js 및 TypeScript 진영에서 Redis, Kafka, gRPC 등 다양한 트랜스포트 계층을 지원하며 구조화된 분산 시스템 설계를 제공하는 현대적 프레임워크의 실전 패턴이기 때문입니다 [6, 7].
|
|
* 이 개념을 통해 더 깊게 이해할 수 있는 부분: 의존성 주입(DI)과 모듈 시스템을 통해 분산형 백엔드 환경에서 객체 지향적 원칙을 어떻게 강제하고 스케일링하는지 배울 수 있습니다 [6, 23].
|
|
|
|
### Deeper Research Questions
|
|
- 대규모 분산 시스템 환경에서 넷플릭스의 Mogul과 같이 수만 개의 메트릭 속에서 성능 병목의 근본 원인(Root cause)을 찾아내는 텔레메트리 최적화 파이프라인은 어떻게 설계되는가? [10, 24]
|
|
- 마이크로서비스 간 통신에서 동기식 HTTP의 병목 현상을 방지하기 위해, 이벤트 기반 비동기 메시징 아키텍처와 백프레셔(Back pressure) 제어를 어떻게 구현해야 하는가? [13]
|
|
- 모놀리식 시스템을 마이크로서비스로 성공적으로 분리하기 위해 서비스의 도메인 경계(Bounded Context)를 식별하고 나누는 기준은 무엇인가? [12, 18, 25]
|
|
- 분산 시스템에서 다중 서비스에 걸친 트랜잭션의 원자성(Atomicity)과 일관성(Consistency)을 유지하기 위해 2단계 커밋(2PC)이나 Saga 패턴을 어떻게 적용해야 하는가? [26]
|
|
- Spring Boot의 AOP 및 NestJS의 Interceptor는 MSA의 분산 로깅, 인증과 같은 횡단 관심사(Cross-cutting concerns)를 개별 서비스 코드 오염 없이 어떻게 처리하는가? [6, 7, 21, 22]
|
|
|
|
### Practical Application Contexts
|
|
- **Implementation:** Spring Boot Initializr를 통해 Eureka Server나 Feign, Zuul 모듈을 생성하거나, NestJS의 다중 트랜스포트 계층을 활용해 독립된 마이크로서비스 애플리케이션들을 구현할 수 있습니다 [5, 6, 27].
|
|
- **System Design:** "시스템 설계는 조직의 통신 구조를 닮는다"는 콘웨이의 법칙(Conway's Law)을 적용하여, 제품 팀의 역량과 구조에 맞춰 서비스의 아키텍처 경계를 그리는 방향으로 시스템을 디자인해야 합니다 [2, 28].
|
|
- **Operation / Maintenance:** 모니터링 사각지대를 방지하기 위해 서비스의 요청 ID(Request ID)를 모든 로깅 이벤트에 기록(Traceability)하고, 실시간 시스템 상태와 에러 관리를 위해 포괄적인 관제 시스템(예: Vector, Atlas)을 운영 단계에 필수적으로 편입시킵니다 [11, 29, 30].
|
|
- **Learning Path:** 우선 단일 애플리케이션 내부에서 모듈을 나누어 비즈니스 로직을 구현하는 경험을 쌓은 후, 확장의 한계가 왔을 때 점진적으로 서비스 디스커버리와 API 게이트웨이 등의 분산 통신 패턴을 학습해 나가는 경로를 따릅니다 [18].
|
|
- **My Project Relevance:** 현재 다루는 프레임워크(Spring Boot 혹은 NestJS)가 제공하는 의존성 주입과 모듈 구조가 마이크로서비스로 분할될 때, 기존의 로직을 손상시키지 않고 독립된 서비스로 안전하게 분리해 내기 위한 설계 참조 모델로 활용할 수 있습니다 [7, 18].
|
|
|
|
### Adjacent Topics
|
|
- [[Domain-Driven Design (DDD)]]
|
|
* 확장 방향: 마이크로서비스 아키텍처에서 서비스 단위(모듈)를 나눌 때 기준이 되는 '바운디드 컨텍스트(Bounded Context)'와 도메인 중심의 코드 조직화 전략을 심층적으로 연결하여 조사합니다 [6, 25, 31].
|
|
|
|
---
|
|
*Last updated: 2026-05-03* |