뱅크샐러드가 게임을 만들 때 데이터 정합성을 유지하는 법 (feat. 낙관적 락)
문제게임형 앱테크 서비스의 character_state(잔액·레벨)는 유저 액션·운영 백오피스·배치 등 여러 경로로 동시에 갱신된다. 동시성 제어가 없으면 Lost Update 가 발생해 현금성 자산 정합성이 깨진다.
접근재시도 로직 없는 낙관적 락을 채택. version 컬럼을 두고 UPDATE 시 WHERE version = ? 조건으로 CAS 한다. 충돌 시 즉시 실패시켜 호출자가 처리하도록 위임한다.
결과잠금 대기 없이 정합성을 보장하고 코드 복잡도를 낮췄다. 현금성 재화가 오가는 도메인에서도 트랜잭션 단순화와 동시성 안전성을 동시에 확보했다.
