kt-event-marketing/claude/sequence-inner-design.md
2025-10-22 14:13:57 +09:00

3.7 KiB

내부시퀀스설계 가이드

[요청사항]

  • <작성원칙>을 준용하여 설계
  • <작성순서>에 따라 설계
  • [결과파일] 안내에 따라 파일 작성

[가이드]
<작성원칙>

  • 유저스토리와 매칭되어야 함. 불필요한 추가 설계 금지
  • 외부시퀀스설계서에서 설계한 플로우와 일치해야 함
  • UI/UX설계서의 '사용자 플로우'참조하여 설계
  • 마이크로서비스 내부의 처리 흐름을 표시
  • 각 서비스-시나리오별로 분리하여 각각 작성
  • 각 서비스별 주요 시나리오마다 독립적인 시퀀스 설계 수행
  • 프론트엔드와 백엔드 책임 분리: 프론트엔드에서 할 수 있는 것은 백엔드로 요청 안하게 함
  • 표현 요소
    • API 레이어: 해당 시나리오의 모든 관련 엔드포인트
    • 비즈니스 레이어: Controller → Service → Domain 내부 플로우
    • 데이터 레이어: Repository, Cache, External API 접근
    • 인프라 레이어: 메시지 큐, 이벤트, 로깅 등
  • 다이어그램 구성
    • 참여자(Actor): Controller, Service, Repository, Cache, External API
    • 생명선(Lifeline): 각 참여자의 활동 구간
    • 메시지(Message): 동기(→)/비동기(-->) 호출 구분
    • 활성화 박스: 처리 중인 시간 구간 표시
    • 노트: 중요한 비즈니스 로직이나 기술적 고려사항 설명
  • 참여자가 서비스 내부가 아닌 다른 마이크로 서비스, 외부시스템, 인프라 컴포넌트면 참여자 이름 끝에 '<>'를 붙임 예) database "Redis Cache<>" as cache

<작성순서>

  • 준비:
    • 유저스토리, UI/UX설계서, 외부시퀀스설계서 분석 및 이해
    • "@analyze --play" 프로토타입이 있는 경우 웹브라우저에서 실행하여 서비스 이해
  • 실행:
    • <시나리오 분류 가이드>에 따라 각 서비스별로 시나리오 분류
    • 내부시퀀스설계서 작성
      • <병렬수행>가이드에 따라 동시 수행
      • PlantUML 스크립트 파일 생성 즉시 검사 실행: 'PlantUML 문법 검사 가이드' 준용
  • 검토:
    • <작성원칙> 준수 검토
    • 스쿼드 팀원 리뷰: 누락 및 개선 사항 검토
    • 수정 사항 선택 및 반영

<시나리오 분류 가이드>

  • 시나리오 식별 방법
  • 유저스토리 기반: 각 유저스토리를 기준으로 시나리오 도출
  • 비즈니스 기능 단위: 하나의 완전한 비즈니스 기능을 수행하는 단위로 분류
  • 시나리오별 설계 원칙
    • 단일 책임: 하나의 시나리오는 하나의 명확한 비즈니스 목적을 가짐
    • 완전성: 해당 시나리오의 모든 API와 내부 처리를 포함
    • 독립성: 각 시나리오는 독립적으로 이해 가능해야 함
    • 일관성: 동일한 아키텍처 레이어 표현 방식 사용
  • 시나리오 명명 규칙
    • 케밥-케이스 사용: entity action 형태. 한글로 작성 (예: 사용자 등록, 주문 처리)
    • 동사형 액션: 실제 수행하는 작업을 명확히 표현
    • 일관된 용어: 프로젝트 내에서 동일한 용어 사용

<병렬수행>

  • 서브 에이전트를 활용한 병렬 작성 필수
  • 서비스별 독립적인 에이전트가 각 내부시퀀스설계를 동시에 작업
  • 모든 설계 완료 후 전체 검증

[참고자료]

  • 유저스토리
  • UI/UX설계서
  • 외부시퀀스설계서
  • 프로토타입

[예시]

[결과파일]

  • design/backend/sequence/inner/{서비스명}-{시나리오}.puml
  • 서비스명은 영어로 시나리오명은 한글로 작성