inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

동시성 이슈 처리 질문있습니다!

해결된 질문

280

jiny

작성한 질문수 23

1

DB 동시성 문제를 해결하기 위해

낙관적 잠금, 유니크 제약조건, 비관적 잠금이 있는 것으로 알고있습니다.

비관적 잠금은 성능상의 이유로 잘 사용하지 않는다고 알고있어서

낙관적 잠금 또는 유니크 제약조건으로 동시성을 해결하고 있는데,

 

낙관적 잠금을 사용해야 할지, 유니크 제약 조건을 사용해야 할지 의문이 들어 질문 드립니다.

 

감사합니다!

spring mvc spring-jdbc

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요. 동시성 이슈 처리에 관해 궁금하신 것 같네요.

일반적으로 비관적 잠금은 동시성 이슈를 처리하기 위한 방법 중 하나이지만, 성능상의 이유로 잘 사용되지 않는 경우가 많습니다. 그래서 낙관적 잠금과 유니크 제약조건을 주로 활용하는데요.

낙관적 잠금은 충돌이 발생하지 않는다고 가정하고 작업을 수행한 후에 충돌이 발생할 경우 조치를 취하는 방식입니다. 여기서는 데이터베이스에서 제공하는 버전 처리나 타임스탬프 등을 활용하여 충돌을 감지하고 처리합니다. 하지만 충돌이 잦은 경우에는 성능에 영향을 주므로 주의해야 합니다.

반면 유니크 제약 조건은 데이터베이스에서 중복 데이터를 허용하지 않도록 제약을 설정하는 방식입니다. 유니크 제약 조건을 사용하면 동시에 같은 값을 입력하려는 작업들을 제한할 수 있어서 동시성 문제를 해결할 수 있습니다.

낙관적 잠금과 유니크 제약 조건은 서로 다른 방식으로 동시성 문제를 처리하는데, 어떤 방식을 사용해야 하는지는 상황에 따라 다를 수 있습니다. 개발하시는 시스템의 성능 요구사항과 동시성 이슈의 종류를 고려하여 선택하는 것이 좋습니다.

더 자세한 내용이나 특정 상황에 대한 조언이 필요하시다면, DBMS 종류, 동시성 이슈의 세부 내용 등을 알려주시면 더욱 정확한 도움을 드릴 수 있을 것 같습니다. 감사합니다.

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

38

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

51

1

jdbc 학습하다 궁금해서 질문드려요

0

84

1

정상이체와 이체중 예외발생 차이

0

70

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

89

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

59

2

데이터베이스 선택 관련 질문.

0

69

2

after 메서드 사용 유무

0

59

2

데이터베이스 접근 및 DB 락

0

57

1

@SpingBootTest, @TestConfiguration

0

57

1

Read Committed 격리 수준 사용 관련 질문

0

50

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

69

2

커리큘럼 관련 질문

0

78

1

서비서 계층 스프링 프레임워크 사용

0

89

1

validation(toMember)의 위치

0

84

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

166

2

member 상수 질문

0

124

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

154

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

110

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

103

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

116

2