인프런 커뮤니티 질문&답변

seon님의 프로필 이미지
seon

작성한 질문수

스프링 핵심 원리 - 고급편

이중화된 서버에서 동시성 제어할 수 있는 방법 질문 드립니다!

해결된 질문

작성

·

673

·

수정됨

0

안녕하세요 강사님 이번에 새로운 출발한다는 소식을 들었는데 진심으로 응원드립니다!

오늘 ThreadLocal 강의를 듣던 중 궁금한 점이 생겨 질문드립니다.

  1. 이중화된 서버의 경우 동시성 제어를 DB LOCK을 활용해야 하나요? 실무에서는 주로 어떤 방법으로 제어하나요?

  2. 영화 예매 기능을 구현할 때
    영화 정보 테이블(해당 시간에 상영하는 영화의 자리수를 가지고 있음)
    예매 내역 테이블(예매한 사람의 인적사항을 가지고 있음)

    해당 회차의 예매 가능한 총 자리수 - 해당 회차를 신청한 자리수에 신청하려는 인원수를 빼서 0보다 같거나 크면 신청할 수 있도록 아니면 예외를 throws하는 설계입니다..
    위 설계대로 서비스 레이어에서 아래와 같이 구현하면 신청자 수를 count하는 SQL에 SELECT LOCK을 걸어주는게 맞을까요?

    @Transactional
    public void 예매신청(PersonDTO params) {
    int result = dao.총자리수() - dao.예매한수();
    if (result - params.get신청하려는예매인원수() >= 0) {
    신청 로직~~~
    } else {
    throw new IllegalStateException("자리 없음!");
    }

늘 좋은 강의 해주셔서 감사합니다 덕분에 많이 늘고 있습니다!

답변 1

2

안녕하세요. seon님, 공식 서포터즈 David입니다.

  1. 네, DB의 lock을 사용하셔야 합니다.

  2. 총 신청자 수를 구하고 신청하는 구간을 락 걸어야 할 것 같습니다. 이 부분에 대한 건 다음 글을 참고하시면 해결하시고자 하는 것에 대한 힌트를 얻을 수 있을 것 같습니다. https://techblog.woowahan.com/2631

감사합니다.

seon님의 프로필 이미지
seon
질문자

감사합니다!

seon님의 프로필 이미지
seon

작성한 질문수

질문하기