docs(ranking): 스냅샷 lock 계획을 기록한다
This commit is contained in:
@@ -208,13 +208,17 @@
|
||||
- 순위 변화는 최신 완료 주차 응답에서 부여된 순위와 직전 완료 주차 스냅샷 기준 순위를 비교해 계산한다.
|
||||
- 동점 랜덤 정렬 정책 때문에 동점 구간에 포함된 크리에이터의 순위와 순위 변화는 조회 결과마다 달라질 수 있으며, 이는 허용한다.
|
||||
- 스냅샷 생성은 이번 주 데이터가 포함되지 않도록 주간 집계 대상 기간이 종료된 뒤 실행한다.
|
||||
- 기본 스케줄 후보는 매주 월요일 KST 06:00이며, 스케줄러는 `Asia/Seoul` zone을 명시한다.
|
||||
- 기본 스케줄 후보는 매주 월요일 KST 07:30이며, 스케줄러는 `Asia/Seoul` zone을 명시한다.
|
||||
- 다중 서버 인스턴스에서 같은 스케줄이 동시에 실행되더라도 클러스터 전체에서 한 인스턴스만 스냅샷 생성을 수행해야 한다.
|
||||
- 클러스터 단일 실행은 신규 DB 테이블을 추가하지 않고, 기존 프로젝트에 설정된 Redisson 기반 분산 lock을 우선 사용한다.
|
||||
- 주간 랭킹 스냅샷 lock key는 `lock:creator-ranking-snapshot-refresh`를 사용하며, lock 획득 실패 인스턴스는 스냅샷 생성을 skip한다.
|
||||
- 같은 집계 기간에 대해 스냅샷을 재생성할 수 있어야 하며, 재생성 시 기존 같은 기간 스냅샷을 중복 노출하지 않는다.
|
||||
- 조회 API는 최신 완료 주차의 스냅샷을 기준으로 응답한다.
|
||||
|
||||
#### Edge Cases
|
||||
- 최신 완료 주차 스냅샷이 없으면 빈 배열로 성공 응답하고, 장애 추적용 로그를 남긴다.
|
||||
- 스냅샷 생성 중 일부 원천 집계가 실패하면 해당 주차 스냅샷 저장을 실패 처리하고 부분 결과를 공개하지 않는다.
|
||||
- Redisson lock 획득 실패는 다른 인스턴스가 같은 작업을 수행 중인 정상 skip으로 처리하고, 스냅샷 생성 실패로 집계하지 않는다.
|
||||
|
||||
### Feature I. 랭킹 계산 컴포넌트 분리
|
||||
|
||||
@@ -245,6 +249,7 @@
|
||||
- QueryDSL 또는 native SQL 중 기존 성능/패턴에 맞는 방식을 선택하되, 산식 자체는 테스트 가능한 domain/application 정책으로 분리한다.
|
||||
- 주간 랭킹 조회는 스냅샷 기반으로 제공한다.
|
||||
- 캐싱은 이번 PRD의 필수 구현은 아니지만, 랭킹 조회 서비스가 캐시 포트를 도입할 수 있는 구조여야 한다.
|
||||
- 스냅샷 스케줄러는 기존 Redisson 설정을 재사용해 클러스터 단일 실행을 보장하고, 별도 scheduler lock용 DB 테이블은 추가하지 않는다.
|
||||
|
||||
---
|
||||
|
||||
|
||||
Reference in New Issue
Block a user