Spring Boot/스프링 부트 핵심 가이드
[SpringBoot] 2.1-3 스프링 부트 동작 방식, 레이어드 아키텍처
nayonsoso
2023. 7. 23. 21:25
Summary : 효율을 위해 마이크로 아키텍처 구조를 가져야 하지만, 이를 위해선 서버간 통신이 필요
통신에서의 역할별로 계층을 나눈게 레이어드 아키텍처
🔍 목차
02 개발에 앞서 알면 좋은 기초 지식
2.1 서버 간 통신
2.2 스프링 부트의 동작 방식
2.3 레이어드 아키텍처
📌 2.1 서버 간 통신
단일 서비스 아키텍처 : 하나의 서비스 단위로 개발하는 것
- 장점 : 하나의 서비스에서 모든 자원을 공유하므로 원하는 자원에 쉽게 접근 가능
- 단점
1) 서비스의 규모가 크므로 시간이 오래 걸림
2) 한 부분이 고장 나면 전체가 다운될 수 있음
이러한 문제를 해결하기 위해 나온 것이 마이크로 서비스 아키텍처(MSA)
마이크로 서비스 아키텍처 : 서비스를 작게 나누어 개발하는 것
- 장점
1) 단일 모듈의 장애에 전체 어플리케이션이 크게 영향받지 않음
2) 각 서비스를 테스트하기 용이
3) 느슨한 결합으로 인해 의존 관계가 적고 유연 - 단점 : 자원 공유가 안되므로 서비스끼리 통신을 해야 정보를 주고받을 수 있음
- => 이런 상황에서의 통신을 '서버간 통신'이라고 함
📌 2.2 서블릿
- 서블릿의 특징
1) 클라이언트의 요청에 동적으로 응답하는 웹 어플리케이션 컴포넌트
2) HTTP 형식으로 응답
3) JAVA의 스레드를 이용
4) MVC 패턴의 Controller 역할을 담당
5) 서블릿은 서블릿 컨테이너에서 관리됨 - 서블릿은 WAS내의 서블릿 컨테이너에서 동작하며,
요청(Request)을 받으면 요청에 맞는 로직을 실행하고
클라이언트에게 HTTP 형식으로 응답(Response)함 - 스프링에서는 DispatcherServlet이 서블릿의 역할을 수행
📌 2.2 서블릿 컨테이너
톰캣의 작동 방식
- 톰캣은 대표적인 서블릿 컨테이너
- 톰캣은 클라이언트로부터 요청을 받았을 때,
요청에 대응할 수 있는 서블릿 클래스를 인스턴스화하여 요청을 처리함 - 이때 서블릿 객체는 컨테이너 안에서 싱글톤 패턴으로 생성됨
서블릿 컨테이너의 역할
- 웹서버와의 통신 지원 : 서블릿이 담당하지 않는 부가적인 기능을 처리해 주므로 개발에만 집중할 수 있음
- 서블릿 객체의 생명주기 관리 : 인스턴스 생성, 초기화 호출, 종료 etc..
- 멀티 스레드 지원
📌 2.2 스프링 부트의 동작 방식
- DispatcherServlet 으로 요청(HttpServletRequest)이 들어오면
DispatcherServlet은 핸들러 매핑(Handler Mapping)을 통해 요청 URL에 매핑된 핸들러를 탐색한다.
여기서 핸들러는 컨트롤러(Controller)를 의미한다. - 이후, DispatcherServlet은 핸들러 어댑터(HandlerAdapter)로 컨트롤러를 호출한다.
- 핸들러 어댑터에 컨트롤러의 응답이 돌아오면 응답을 가공하여 DispatcherServlet에게 반환한다.
- 응답을 가공하는 방법
뷰 형식으로 리턴하는 컨트롤러를 사용할 경우 뷰 리졸버(ViewResolver)를 통해 뷰(View)를 받아 리턴한다.
뷰 없이 JSON만 리턴하는 경우에는 MessageConverter을 사용해서 Json을 body에 넣어 HTTP 응답을 리턴한다.
cf. MessageConverter란?
JSON 데이터를 HTTP 메시지 바디안에 직접 읽거나 쓰는 경우 사용함
사용 예시 :
@RestController를 이루는 어노테이션 @ResponseBody은 자바 객체를 json으로 바꾸는 역할을 하는데,
이때 @ResponseBody의 내부에서 HttpMessageConverter가 동작함
📌 2.3.1 레이어드 아키텍처 (Layered Architecture)
- 정의 : 애플리케이션의 컴포넌트를 유사 관심사를 기준으로 레이어로 묶어 수평적으로 구성한 구조
- 각 레이어는 아래의 역할을 함
프레젠테이션 계층
- 클라이언트와의 유일한 접점
- 클라이언트로부터 데이터와 함께 요청을 받고, 처리 결과를 응답으로 전달하는 영역
- 상황에 따라 유저 인터페이스(UI / User Interface) 계층이라고도 함
비즈니스 계층
- 핵심 비즈니스 로직을 구현하는 영역
- 트랜잭션 처리나 유효성 검사 등의 작업도 수행함
- 상황에 따라 서비스(Service) 계층이라고도 함
데이터 접근 계층
- 데이터베이스에 접근해야 하는 모든 작업을 수행하는 영역
- 상황에 따라 영속(Persistence) 계층이라고도 함
레이어드 아키텍처 기반 설계의 특징
- 각 레이어는 가장 가까운 하위 레이어의 의존성을 주입받음
- 각 레이어는 관심사에 따라 묶여 있으며, 다른 레이어의 역할을 침범하지 않음
- 각 컴포넌트의 역할이 명확하므로 코드의 가독성과 기능 구현에 유리함
- 코드의 확장성도 좋아짐
- 각 레이어가 독립적으로 작성되므로 다른 레이어와의 의존성을 낮춰 단위 테스트에 용이함
📌 2.3.2 스프링에서의 레이어드 아키텍처
- 스프링 부트는 별도의 설정 없이 spring-boot-starter-web의 의존성을 사용할 때
기본적으로 Spring MVC(Model- View-Controller) 구조를 갖음 - Spring MVC를 레이어드 아키텍처로 생각하면
View와 Controller는 프레젠테이션 계층이며,
Model은 비즈니스와 데이터 접근 계층으로 구분할 수 있음 - 여기서 Model은 DTO와 같은 역할을 하고, DAO는 리포지토리와 같은 역할을 함
참고 블로그 :
https://code-lab1.tistory.com/210
https://jaimemin.tistory.com/1823