스프링에서 Repository, Service, Controller 구분하는 이유

  • 2 minutes to read

스프링에서 Controller에서 모든 것을 다 처리하고, Repository 또는 Service 클래스를 만들지 않아도 상관은 없습니다.

하지만, 하나의 주제에 따라서 하나 이상의 리포지토리와 서비스 클래스를 만들고 이를 컨트롤러 클래스에서 사용되는 방식으로 진화해 오고 있습니다.

일반적인 사용 흐름은 다음과 같습니다.

  • DB -> Repository -> Service -> Controller -> View

데이터 저장소(DB, Data Store)

실제 데이터가 저장되어 있는 곳을 말합니다.

흔히 우리가 사용하는 DB를 의미합니다.

요즘은 SQL Server, Postgres와 같은 관계형 데이터베이스 이외에 NoSQL 기반의 데이터베이스도 많이 있기에 이 모든 영역을 DB로 봅니다.

Heros.sql

리포지토리(Repository)

데이터 저장소와 연결되어 데이터를 처리하는 영역입니다.

JPA와 밀접하게 연결되어 있는 레이어입니다.

HeroRepository.java

서비스(Service)

하나 이상의 리포지토리를 묶어서 관리하는 목적으로 사용됩니다.

물론, 하나의 리포지토리와 하나의 서비스만 연결해도 됩니다.

HeroService.java

컨트롤러(Controller)

스프링과 같은 MVC에서는 컨트롤러가 핵심 관문 역할입니다.

컨트롤러에서 모든 역할을 다하고 그 결과를 뷰(View)에 전달하여 출력하는 구조이지만,

데이터 처리 관련해서는 리포지토리와 서비스 레이어를 구분지어 관리합니다.

컨트롤러에서 직접 리포지토리에 접근해서 사용해도 되지만,

일반적으로 컨트롤러에서는 서비스 클래스를 사용합니다.

컨트롤러 클래스에서 사용하는 모델 클래스를 DTO(Data Transfer Object)라고도 합니다.

HeroController.java
HerosController.java
...
더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com