본문 바로가기

TIL

[SpringFramework][Architecture]

728x90

학습 목표

  • 아키텍처(Architecture)의 의미를 이해할 수 있다.

아키텍처는 건축분야에서 유래된 용어로써 요구사항을 만족하는 건축물을 짓는 데 있어 청사진 같은 역할을 한다

컴퓨터 시스템에서 아키텍처 유형

시스템 아키텍처

시스템 아기텍처는 하드웨어와 소프트웨어를 모두 포함하는 어떤 시스템의 전반적인 구성을 큰 그림으로 표현한 것이다

또한 해당시스템 구성 요소들 간의 상호작용이 어떻게 이루어지는지 등 시스템 정상적으로 동작하기 위한 시스템 아키텍처 안에 표현이 되면 이해 당사자들이 해당 아키텍처를 이해하는데 도움이 된다

 

시스템 아키텍처 사례

시스템아키텍처를 어떤 식으로 표현하는지, 그리고 어떤 아키텍처를 점직적으로 개선해 나가는 모습을 알아보자

 

  • 우리가 알아야 할 애플리케이션의 아키텍처를 이해할 수 있다.

웹 애플리케이션을 위한 아키텍쳐

 

애플리케이션은 소프트웨어 종류의 하나로써 좁게는 데스트탑이나 스마트폰에서 사용하는 응용 프로그램을 말하며 넓게는 클라이언트의 요청을 처리하는 서버 애플리케이션을 의미한다

애플리케이션의 아키텍처 유형에는 다양한 유형이 있지만 앞으로 만들게 될 웹 애플리케이션과 연관이 있는 계층형 아키텍처이다

API계층

API계층은 클라이언트의 요청을 받아들이는 계층이다 일반적으로 표현 계층이라고도 불리지만 REST API를 제공하는 애플리케이션의 경우 API 계층이라고 표현한다

서비스 계층

 서비스 계층은 API계층에서 전달받은 요청을 업무 도메인의 요구 사항에 맞게 비즈니스적으로 처리하는 계층이다 애플리케이션의 핵심 로직은 서비스 계층에 포함되어 있다고 해도 과언이 아닐 만큼 애플리케이션에 있어 핵심이 되는 계층이다.

 

도메인이란

애플리케이션 개발에서 흔하게 사용하는 도메인이란 용어는 주로 비즈니스적인 어떤 업무 영역과 관련이 있다. 예를 들어 새로운 배달 주문 앱을 만들어야 한다면 고객과 음식점, 배달원, 그리고 카드사 또는 은행 등 배달 주문 앱을 구현하기 위해 필요한 업무들을 자세히 알면 알수록 퀄리티가 높은 애플리케이션을 만들 가능성이 높다. 즉, 고객이 음식을 주문하는 과정, 주문받은 음식을 처리하는 과정, 조리된 음식을 배달하는 과정 드의 도메인 지식들을 서비스 계층에서 비즈니스 로직으로 구현해야 하는 것이다 애플리케이션을 제작하기 위한 기술도 중요하지만 애플리케이션에서 비즈니스 로직으로 표현해야 하는 도메인 지식 역시 아주 중요하다

 

데이터 액세스 계층 : 비즈니스 계층에서 처리된 데이터를 데이터베이스 등의 데이터 ㅈ버장소에 저장하기 위한 계층이다.

 

Point

소프트웨어의 구성을 큰 그림으로 표현한 것이 소프트웨어 아키텍처이다.

애플리케이션은 소프트웨어 종류의 하나로써 좁게는 데스크톱이나 스마트폰에서 사용하는 응용프로그램을 말하며, 넓게는 클라이언트의 요청을 처리하는 서버 애플리케이션을 의미한다.

애플리케이션의 아키텍처 중 중점적으로 알아야 할 아키텍처는  계층형 애플리케이션 아키텍처이다.

REST API 기반 웹 애플리케이션은 계층은 크게 API계층, 비즈니스 계층, 데이터 액세스 계층으로 구분된다

aPi계층은 클라이언트의 요청을 받아들이는 계층이다

비즈니스 계층은 API계층에서 전달받은 요청을 업무 도메인의 요구 사항에 맞게 비즈니스적으로 처리하는 계층이다.

데이터 액세스 계층은 비즈니스 계층에서 처리된 데이터를 데이터베이스 등의 데이터 저장소에 저장하기 위한 계층이다.

 

  • 아키텍처를 통해 Spring Framework의 모듈(Module) 구성을 이해할 수 있다.

모듈이란?

Java에서는 일반적으로 지원되는 여러 가지 기능들을 목적에 맞게 그룹화하여 묶어 놓은 것을 모듈이라고 부른다

이러한 모듈은 java의 패키지 단위로 묶여 있으며 이 패키지안에는 관련 기능을 제공하기 위한 클래스들이 포함되어 있다. 일반적으로 모듈은 재사용 가능하도록 라이브러리 형태로 제공되는 경우가 많다.

728x90

'TIL' 카테고리의 다른 글

[SpringMVC][Spring Data JDBC]  (0) 2022.10.27
[SpringBoot][SpringBoot란?]  (0) 2022.10.22
[SpringFramework][PSA]  (0) 2022.10.22
[Spring][SpringMVC][Controller][패키지구조]  (0) 2022.10.21
[Spring MVC] [Spring API계층]  (0) 2022.10.20