트랙잭션 격리수준 선택에 대해서 질문
2
작성한 질문수 143
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
안녕하세요. 궁금증이 생겨서 질문을 드립니다.
현재 듣고 있는 "트랜잭션 -개념 이해" 에서 격리수준에 대해서 설명할때 일반적으로 "READ COMMITTED"을 사용하고 이것에 대해서 설명한다고 했습니다.
"db - 기본 -11번 트랙잭션" 편에서 격리 수준을 설명 할때, 사진을 보면

이렇게 격리 수준이 "REPEATABLE READ"로 바뀌어져 있는데요.
그래서 궁금증은
지금 백엔드 개발을 한다면, "REPEATABLE READ" 이게 맞는 건가요? 아니면 "READ COMMITTED" 이게 맞는 건가요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 생각하는자 님의 궁금증에 대해 설명드리겠습니다.
트랜잭션 격리 수준은 데이터베이스의 동시성과 무결성을 어떻게 관리할 것인지 결정하는 중요한 요소입니다. 각각의 격리 수준은 장단점이 있으며, 다양한 상황에 맞춰 선택 할 수 있습니다.
READ COMMITTED:
- 실제로 많은 시스템에서 기본적으로 사용되는 격리 수준입니다.
- 트랜잭션이 완료(커밋)되지 않는 한 다른 트랜잭션이 해당 데이터를 읽지 못하게 합니다.
- 일반적으로 성능이 좋고 락 경합이 적지만, 리피터블 리드나 팬텀 리드의 문제가 발생할 수 있습니다.
- 실제로 많은 시스템에서 기본적으로 사용되는 격리 수준입니다.
REPEATABLE READ:
- 한 번 읽은 데이터를 다시 읽을 때 같은 값을 보장하기 때문에 데이터의 일관성을 유지할 수 있습니다.
- MySQL의 기본 설정이며, 좀 더 강력한 데이터 정합성을 보장하지만 성능상 손해가 발생할 수 있습니다.
- 한 번 읽은 데이터를 다시 읽을 때 같은 값을 보장하기 때문에 데이터의 일관성을 유지할 수 있습니다.
백엔드 개발에서 어느 격리 수준을 사용할지 결정할 때는 시스템의 요구사항, 데이터 정합성의 중요성, 동시 사용자 수 등을 고려해야 합니다. 일반적으로는 READ COMMITTED 수준으로 시작하여 상황에 맞춰 조정하는 것이 좋습니다. 하지만, 데이터 일관성이 매우 중요하다면 REPEATABLE READ나 더 높은 격리 수준을 고려할 수 있습니다.
관련하여 참고할 만한 추가 질문들을 다음에서 확인하실 수 있습니다:
1. 1차 캐시와 트랜잭션 격리 수준
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
60
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
72
1
jdbc 학습하다 궁금해서 질문드려요
0
102
1
정상이체와 이체중 예외발생 차이
0
84
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
103
1
순수한 서비스 계층에 대한 의문???
0
91
2
3_4test, 4test 자동 리소스 안됨
0
65
2
데이터베이스 선택 관련 질문.
0
76
2
after 메서드 사용 유무
0
67
2
데이터베이스 접근 및 DB 락
0
65
1
@SpingBootTest, @TestConfiguration
0
67
1
Read Committed 격리 수준 사용 관련 질문
0
61
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
74
2
커리큘럼 관련 질문
0
84
1
서비서 계층 스프링 프레임워크 사용
0
99
1
validation(toMember)의 위치
0
91
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
178
2
member 상수 질문
0
137
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
170
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
121
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
125
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
107
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
104
1
강의 14분쯤 Exception 질문
0
123
2





