inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

트랜잭션에 궁금함이 있습니다.

329

화이팅

작성한 질문수 37

0

안녕하세요. 강사님 강의를 정주행중인 학생입니다.
아직 디비 관련 강의를 듣기 전인데 실제 프로젝트를 하다 궁금함이 있어 질문드립니다.
 
비즈니스 로직상 동일한 사용자 아이디를 등록할 수 없습니다.
테이블 상 유니크 제약 조건은 사용하지 않고 비지니스 로직에서 에러 처리를 하기위해
사용자를 등록 시 최초 동일한 아이디가 있는지 디비에서 검색합니다.
 
그 다음 동일한 아이디가 없을 때 먼저 다른 서버에 데이터를 등록 요청 후
디비에 사용자를 등록합니다.
성능 테스트를 위해 api를 여러번 호출했습니다.
요청당 각 별도의 쓰레드로 실행되다 보니 몇개는 동일한 아이디가 여러개 등록됩니다.
현재는 멀티 프로세스 환경을 사용할 계획이 없어서 synchronized 키워드를 사용하여 동기화 처리를 했습니다.
 
더 나아가 궁금한 점은
  1. 단일 프로세스 환경이면 동기화로 처리하는 방법은 좋은 방법일까요?
    tps가 많을 경우 속도 느려진다는 단점이 있을 것 같습니다.
    tps 많다면 결국 서버를 늘려야 하겠죠. 그럼 결국 멀티 프로세스 환경으로 넘어가네요..ㅎㅎ...
  2. 멀티 프로세스 환경(다중 서버)일 경우 어떤식으로 처리하는게 좋을까요?
  3. 강사님이 다른 질문에 올려주신 디비에 유니크 제약 조건을 이용하여 공통 예외 처리를 하는 내용도 봤습니다.
    다른 서버에 데이터 등록 요청을 하지 않는다면 멀티 프로세스 환경에서도 좋은 방법인 것 같습니다.
    다만 다른 서버에 데이터를 등록했으니 예외를 잡아 등록된 다른 서버 데이터를 삭제 요청 후 에러를 발생시키는게 좋은 방법일까요?
    https://www.inflearn.com/questions/59250
  4. 강사님이 올려주신 디비 강의에 해당 관련 내용이 있는지도 궁금합니다. 있다면 어느 강의에서 볼 수 있을지도 궁금하네요.
  5. 강의에 없다면 어떤 키워드를 참고해서 검색하면 될지도 궁금하네요.

코드도 비슷하게나마 올려봅니다.
@Transactional
public synchronized void createUser(String username){
   ...

   Optional<User> findUserOptional = repository.findByUsername(username);

   if(!findUserOptional.isPresent()){

      ~~~ 블라블라 다른 서버에 데이터 등록(MSA 구조)

      em.persist(user);
   }else{
      throw new RuntimeException("username already exists.");
   }

   ...
}
 

spring

답변 1

1

김영한

안녕하세요. 정민영님

실무에서는 장애 영향 등을 고려해서 항상 서버를 2대 이상 사용하기 때문에 synchronized 키워드를 사용해도 효과가 없습니다.

분산락, 보상트랜잭션을 검색해보시면 도움이 되실거에요.

감사합니다.

트랙잭션 격리수준 선택에 대해서 질문

0

25

1

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

0

61

2

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

0

73

1

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

0

104

1

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

0

86

2

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

0

103

1

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

0

94

2

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

0

66

2

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

0

77

2

after 메서드 사용 유무

0

67

2

데이터베이스 접근 및 DB 락

0

65

1

@SpingBootTest, @TestConfiguration

0

68

1

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

0

62

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

74

2

커리큘럼 관련 질문

0

85

1

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

0

100

1

validation(toMember)의 위치

0

91

2

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

0

178

2

member 상수 질문

0

140

2

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

0

171

2

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

0

121

1

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

0

127

1

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

0

107

1

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

0

105

1