MSA란?

백엔드류·2024년 5월 2일

Software Engineering

목록 보기
1/1

MSA는 소프트웨어 개발 기법 중 하나로, 애플리케이션 단위를 '목적'으로 나누는 것이 핵심이다.


Monolithic vs MSA

MSA가 도입되기 전, Monolithic 아키텍처 방식으로 개발이 이루어졌다. Monolithic은 '한 덩어리'에 해당하는 구조로 이루어져있다. 즉, 모든 기능을 하나의 애플리케이션에서 비즈니스 로직을 구성하여 운영한다. 따라서 개발을 하거나 환경설정에 있어서 간단하다는 장점이 있어 작은 사이즈의 프로젝트에서는 유리하다. 그러나, 시스템이 점점 확장되거나 대규모 프로젝트에서는 단점들이 존재한다.

  • 빌드/테스트 시간의 증가 : 하나를 수정해도 시스템 전체를 빌드해야 함. 즉, 유지보수가 힘듬
  • 작은 문제가 시스템 전체에 문제를 일으킴 : 만약 하나의 서비스 부분에 트래픽 문제로 서버가 다운되면, 모든 서비스 이용이 불가능함
  • 확장성에 불리 : 서비스마다 이용률이 다를 수 있다. 하나의 서비스를 확장하기 위해 전체 프로젝트를 확장해야함



MSA란?

MSA는 좀 더 세분화 시킨 아키텍처라고 말할 수 있다. 한꺼번에 비즈니스 로직을 구성하던 Monolithic 방식과는 다르게 기능(목적)별로 컴포넌트를 나누고 조합할 수 있도록 구축한다.

MSA에서 각 컴포넌트는 API를 통해 다른 서비스와 통신을 하는데, 모든 서비스는 각각 독립된 서버로 운영하고 배포하기 때문에 서로 의존성이 X. 더불어, 하나의 서비스에 문제가 생겨도 다른 서비스에는 영향을 끼치지 않으며 서비스 별로 부분적인 확장이 가능한 장점이 있다.



무조건 MSA을 써야할까?

그렇지만은 않다. MSA는 서비스 별로 호출할 때 API로 통신하므로 속도가 느리다. 그리고 서비스 별로 통신에 맞는 데이터로 맞추는 과정이 필요하기도 하다. Monolithic방식은 하나의 프로세스 내에서 진행되기 때문에 속도 면에서는 MSA보다 훨씬 빠를것이다. 또한, MSA는 DB또한 개별적으로 운영되기 때문에 트랜잭션으로 묶기 힘들다.



정리

서비스별로 분리를 하면서 얻을 수 있는 장점도 있지만, 그만큼 체계적으로 준비돼 있지 않으면 MSA로 인해 오히려 프로젝트의 성능이 떨어질 수도 있다. 프로젝트 목적, 현재 상황에 맞는 아키텍처 방식이 무엇인지 설계할 때 부터 잘 고민해서 선택해야한다.


🔎 참고 : https://gyoogle.dev/blog/computer-science/software-engineering/MSA.html

profile
공부한 내용을 정리한 블로그입니다 & 백엔드 개발자

0개의 댓글