이중화된 서버에서 동시성 제어할 수 있는 방법 질문 드립니다!
안녕하세요 강사님 이번에 새로운 출발한다는 소식을 들었는데 진심으로 응원드립니다!
오늘 ThreadLocal 강의를 듣던 중 궁금한 점이 생겨 질문드립니다.
이중화된 서버의 경우 동시성 제어를 DB LOCK을 활용해야 하나요? 실무에서는 주로 어떤 방법으로 제어하나요?
영화 예매 기능을 구현할 때
영화 정보 테이블(해당 시간에 상영하는 영화의 자리수를 가지고 있음)
예매 내역 테이블(예매한 사람의 인적사항을 가지고 있음)
해당 회차의 예매 가능한 총 자리수 - 해당 회차를 신청한 자리수에 신청하려는 인원수를 빼서 0보다 같거나 크면 신청할 수 있도록 아니면 예외를 throws하는 설계입니다..
위 설계대로 서비스 레이어에서 아래와 같이 구현하면 신청자 수를 count하는 SQL에 SELECT LOCK을 걸어주는게 맞을까요?@Transactionalpublic void 예매신청(PersonDTO params) {int result = dao.총자리수() - dao.예매한수();if (result - params.get신청하려는예매인원수() >= 0) {신청 로직~~~} else {throw new IllegalStateException("자리 없음!");}
늘 좋은 강의 해주셔서 감사합니다 덕분에 많이 늘고 있습니다!
답변 1
2
안녕하세요. seon님, 공식 서포터즈 David입니다.
네, DB의 lock을 사용하셔야 합니다.
총 신청자 수를 구하고 신청하는 구간을 락 걸어야 할 것 같습니다. 이 부분에 대한 건 다음 글을 참고하시면 해결하시고자 하는 것에 대한 힌트를 얻을 수 있을 것 같습니다. https://techblog.woowahan.com/2631
감사합니다.
어드바이스 순서 디폴트 기준이 궁금합니다.
0
56
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
81
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
57
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
54
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
56
1
대상 클래스에 기본 생성자가 없을 때
0
76
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
365
2
final 키워드 사용 관련 질문
0
78
1
안녕하세요
0
66
1
ThradLocal 실무 사례
0
98
2
실무에서의 동시성 문제
0
64
1
로그 등 부가 기능에 대한 테스트코드
0
51
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
67
1
실무 멀티스레딩에 대한 궁금증
0
70
1
안녕하세요 질문있습니다
0
45
1
AspectV3 aop 실행 순서 문의 드립니다
0
38
1
MDC vs AOP 중에 고민중입니다.
0
77
1
순환참조
0
161
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
78
1
빈 후처리에 등록 질문 있습니다.
0
77
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
90
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
118
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
69
1
ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)
0
73
2





