[3-1] 비즈니스 요구사항 정리

ohun·2022년 5월 22일
0

Spring 입문

목록 보기
7/16

비즈니스 요구사항

회원 관리 예제로 백엔드 개발을 들어가보자.

  • 데이터 : 회원 ID, 이름
  • 기능 : 회원 등록, 조회
  • 아직 데이터가 선정되지 않음(가상의 시나리오)

일반적인 웹 애플리케이션 계층 구조

  • 컨트롤러 : 웹 MVC의 컨트롤러 역할, api 만들기
  • 서비스 : (도메인을 가지고) 핵심 비즈니스 로직 구현. 예) 회원 중복가입 금지 구현, ...
  • 리포지토리 : 데이터베이스에 접근, 도메인 객체를 DB에 저장하고 관리
  • 도메인 : 비즈니스 도메인 객체. 예) 회원, 주문, 쿠폰 등 주로 데이터베이스에 저장하고 관리됨

클래스 의존관계

  • 아직 데이터 저장소가 선정되지 않아서, 우선 인터페이스로 구현 클래스를 변경할 수 있도록 설계
    • MemoryMemberRepository 는 향후 저장소(RDB, JPA, Mybatis, ...) 구체적인 기술이 선정되면 바꿔끼울 수 있도록 인터페이스로 구현
  • 데이터 저장소는 RDB, NoSQL 등등 다양한 저장소를 고민중인 상황으로 가정
  • 개발을 진행하기 위해서 초기 개발 단계에서는 구현체로 가벼운 메모리 기반의 데이터 저장소 사용
profile
공부 중입니다.

0개의 댓글