티스토리 뷰
세션1이 트랜잭션을 시작하고 데이터를 수정하는 동안 아직 커밋을 수행하지 않았는데, 세션2에서 동시에 같은 데이터를 수정하게 되면 여러가지 문제가 발생한다. 만약 세션1이 중간에 롤백을 하게 되면 세션2는 잘못된 데이터를 수정하는 문제가 발생한다.
이런 문제를 방지하려면, 세션이 트랜잭션을 시작하고 데이터를 수정하는 동안에는 커밋이나 롤백 전까지 다른 세션에서 해당 데이터를 수정할 수 없게 막아야 한다. 여기서는 데이터베이스 Lock을 이용하여 이 문제를 해결하는 방법을 알아보겠다.
세션1은 memberA의 금액을 500원으로 변경하고 싶고, 세션2는 같은 memberA의 금액을 1000원으로 변경하고 싶다. 데이터베이스는 이런 문제를 해결하기 위해 락(Lock)이라는 개념을 제공한다.
- 세션1은 트랜잭션을 시작한다.
- 세션1은 memberA의 money를 500으로 변경을 시도하기 위해서는 해당 로우의 락을 먼저 획득해야 한다. (세션1이 세션2보다 조금 더 빨리 요청하여 락을 획득했다.)
- 세션1은 락을 획득했으므로 해당 로우에 update sql을 수행한다.
- 세션2는 트랜잭션을 시작한다.
- 세션2도 memberA의 money 데이터를 변경하려고 시도하지만, 세션1에서 락을 먼저 획득했기 때문에 락이 돌아올 때 까지 대기한다.
- 여기서 세션2가 락을 무한정 대기하는 것이 아니라, 락 대기 시간을 넘어가면 락 타임아웃 오류가 발생한다.
세션1은 커밋을 수행하고, 트랜잭션이 종료되었으므로 락을 반납한다.
락을 획득하기 위해 대기하던 세션2가 락을 획득한다.
세션2는 update sql을 수행한다.
세션2는 커밋을 수행하고, 트랜잭션이 종료되었으므로 락을 반납한다.
'Spring' 카테고리의 다른 글
[Spring] 트랜잭션 추상화 (0) | 2025.01.12 |
---|---|
[Spring] 데이터베이스 연결 구조와 트랜잭션 개념 이해하기 (1) | 2024.12.26 |
[Spring] DataSource 이해 (0) | 2024.12.24 |
[Spring] 커넥션 풀 이해하기 (0) | 2024.12.23 |
[Spring] JDBC와 데이터베이스 접근 이해하기 (0) | 2024.12.21 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 문자열
- 리팩토링
- Algorithm
- 릿코드
- webflux
- 스프링부트
- 파이썬
- MySQL
- 백준
- 노마드
- mysql 8.0
- 알고리즘
- Spring
- spring boot
- 그리디
- 코틀린
- 구현
- 스프링 부트
- 김영한
- kotlin
- 코테
- 자료구조
- 인프런
- leetcode
- 북클럽
- 정렬
- 노마드코더
- Real MySQL
- 데이터베이스
- 스프링
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함