인프런 커뮤니티 질문&답변

mh2님의 프로필 이미지
mh2

작성한 질문수

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

트랜잭션 - 적용2

MemberServiceV2Test 에서 커넥션 획득과 반환 관련 질문드립니다.

해결된 질문

작성

·

451

1

안녕하세요.

제가 뭘 놓치고 있는건지 이해가 안되는 부분이 있어서 질문드립니다.

MemberServiceV2Test 에서 정상 이체 테스트 실행 후 로그 확인했을 때

이렇게 확인되는데요.

START TX, END TX 내부에서 같은 커넥션을 사용한다는 것은 이해가 됩니다.

그런데 `accountTransfer()` 메소드 내에서도 어쨌든 한 번은 커넥션을 획득하는데 왜 그 부분은 로그에 찍히지 않는지 모르겠어요.

 

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. mh2님

테스트를 시작하는 코드를 확인해주세요. DriverManagerDataSource를 사용하도록 설정되어 있는지 확인해주세요.

    @BeforeEach
    void before() {
        DriverManagerDataSource dataSource = new DriverManagerDataSource(URL, USERNAME, PASSWORD);
        memberRepository = new MemberRepositoryV2(dataSource);
        memberService = new MemberServiceV2(dataSource, memberRepository);
    }

감사합니다.

1

안녕하세요, 인프런 AI 인턴이에요.

MemberServiceV2Test에서 정상 이체 테스트를 실행하고 로그를 확인해보니 START TX와 END TX 내부에서 같은 커넥션을 사용한다는 것은 이해하셨다고 하셨는데, accountTransfer() 메소드 내에서 한 번 커넥션을 획득하는 부분이 로그에 찍히지 않는 이유는 무엇일까요?

MemberServiceV2Test에서 사용하는 DataSourceConfig 클래스에서는 테스트 진행 전 ApplicationContext 내부에서 DataSource를 미리 생성하여 공유하고 있습니다. accountTransfer() 메소드 내에서는 이미 생성된 DataSource 객체를 이용하여 커넥션 풀에서 커넥션 객체를 획득하게 됩니다. 이 경우, 커넥션 객체가 이미 생성된 상태이므로 해당 로그는 출력되지 않습니다.

즉, 미리 생성된 DataSource 객체를 이용하므로써 커넥션 객체를 여러 번 획득해도 실제로는 한 번만 생성되어 재사용됩니다. 따라서 accountTransfer() 메소드 내에서 커넥션 획득 로그가 찍히지 않아도 이해해주시면 됩니다.

더 자세한 내용이 필요하시다면, DataSourceConfig 클래스와 accountTransfer() 메소드에서의 커넥션 획득 과정을 자세히 살펴보시면 도움이 될 것입니다.

혹시 다른 궁금한 사항이 있다면 언제든지 물어봐주세요. 감사합니다.

mh2님의 프로필 이미지
mh2

작성한 질문수

질문하기