RDBMS 락과 비스니스 로직 전체에 대한 락 질문
249
작성한 질문수 41
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
여기에 질문 내용을 남겨주세요.
안녕하세요 영한님.
항상 좋은 수업 감사합니다.
이번 수업을 통해 MySQL 또는 Postgresql와 같은 대중적인 RDBMS의 경우,
서로 다른 세션에서 시작된 서로 다른 트랜잭션에서
동시에 동일 테이블의 동일 row에 대해 write operation을 수행할 때에는,
별도의 Pessimistic Lock등을 사용하지 않더라도,
RDBMS에서 제공해주는 기본 락이 걸리는 것으로
이해했습니다.
그럼에도 불구하고 상품 주문시 상품의 재고를 감소시키는 등의,
비즈니스 로직 단위의 레이스 컨디션 문제의 경우,
select 후 udpate를 하게 되는데
그 select에서 update되기 전 값을 읽어온다면,
(read operation에 대해서는 rdbms 기본 lock이 안걸리니깐)
여기서 레이스 커디션 문제가 발생하므로,
비즈니스 로직 단위의 레이스 컨디션 문제를 막고자 한다면
DB 락 or 레디스 등 별도의 솔루션을 적용해야 하는
것으로 이해했는데요,
제가 이해한 내용이 맞을지 질문 드립니다.
감사합니다.
답변 1
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
32
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
51
1
jdbc 학습하다 궁금해서 질문드려요
0
82
1
정상이체와 이체중 예외발생 차이
0
68
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
88
1
순수한 서비스 계층에 대한 의문???
0
82
2
3_4test, 4test 자동 리소스 안됨
0
58
2
데이터베이스 선택 관련 질문.
0
68
2
after 메서드 사용 유무
0
57
2
데이터베이스 접근 및 DB 락
0
55
1
@SpingBootTest, @TestConfiguration
0
56
1
Read Committed 격리 수준 사용 관련 질문
0
48
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
66
2
커리큘럼 관련 질문
0
76
1
서비서 계층 스프링 프레임워크 사용
0
88
1
validation(toMember)의 위치
0
83
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
165
2
member 상수 질문
0
121
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
153
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
109
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
100
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
98
1
강의 14분쯤 Exception 질문
0
115
2





