inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Controller 안에서 @Transaction 설정이 다른 2개의 method 호출

200

heekyum kim

작성한 질문수 1

0

@Slf4j
@RestController
public class AController {

  @Autowired AService aService;

  @Autowired BService bService;

  @PostMapping("/api/v2/aaaa")
  public ResponseEntity<ResponseDto> postA(
      @RequestBody @Valid PostADto postADto, HttpServletRequest request) throws Exception {
    A a = aService.getA(request);
    HashMap<String, Object> result = bService.createB(postADto, a);
    ....
  }

위 와 같이 컨트롤러에서 aService.getA(request); 와 bService.createB(postADto, user); 메서드를 호출합니다.

각 메서드는 아래와 같이 선언돼있습니다.

@Transactional(readOnly = true)
public A getA(HttpServletRequest request) {

  ....
  return aRepository.findById(id).orElse(null);
}
@Transactional
public HashMap<String, Object> createB(PostADto postADto, A a) {
   ......
   bRepository.save(postADto.toB());
   ......
   return ...;
}

getA 메서드안에서 TransactionSynchronizationManager.isCurrentTransactionReadOnly(); log 출력했을때 readonly = true로 나오고 readDB로 잘 연결됩니다.

 

하지만 createB 메서드안에서 TransactionSynchronizationManager.isCurrentTransactionReadOnly(); log 출력했을때 readonly = false로 나오는데
실제로는 readDB로 연결되고 query를 발생시켜 아래와 같은 오류가 발생합니다.

Caused by: java.sql.SQLException: The MySQL server is running with the --read-only option so it cannot execute this statement
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
Caused by: java.sql.SQLException: The MySQL server is running with the --read-only option so it cannot execute this statement

 

컨트롤러에 @transactional 을 선언하지 않았기 때문에 각 메서드에서 트랜잭션이 수행되어 getA 메서드에서는 readDB로 createB 메서드에서는 writeDB로 요청이 된다고 알고 있었는데 그런 방식으로 동작이 안되 혼란스럽습니다.

 

어떤 이유로 이런 문제가 발생하는지 궁금합니다.

그리고 왜 이렇게 동작하는지 어느 부분을 학습하면 좋은지 궁금합니다.

spring mvc spring-jdbc

답변 1

1

김영한

안녕하세요 heekyum kim님

데이터베이스가 read, write로 분리되어 있는 상황이군요.

이 부분에 대해서는 직접 도움을 드리기 어렵습니다.

대신에 데이터베이스 연결 설정, 데이터베이스 드라이버 버전 등을 확인해보시는 것을 권장드립니다.

감사합니다.

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

0

31

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

120

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