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

태허키님의 프로필 이미지
태허키

작성한 질문수

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

DataSource 예제2 - 커넥션 풀

커넥션 풀에 커넥션 생성할 때 모든 커넥션이 별도의 쓰레드에서 만들어지는 것 같지 않아요.

작성

·

448

2

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
03:20:57.456 [Test worker] DEBUG com.zaxxer.hikari.pool.HikariPool - MyPool - Added connection conn0: url=jdbc:h2:tcp://localhost/~/test user=SA

03:20:57.463 [MyPool connection adder] DEBUG com.zaxxer.hikari.pool.HikariPool - MyPool - Added connection conn1: url=jdbc:h2:tcp://localhost/~/test user=SA

커넥션 을 풀에 채워주는 과정에 대한 로그를 확인해보니 제일 첫번째 커넥션인 conn0의 경우 [Test worker] 쓰레드에서 생성이 이루어지는것 같은데 첫번째 커넥션은 항상 메인 쓰레드에서 만들어지고 이후 [MyPool connection adder]로 넘어가는 것인가요?

강의 자료와 살짝 달라 질문 드려봅니다.

답변 1

5

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

안녕하세요. 태허키님 좋은 질문입니다.

커넥션 풀을 생성하는 별도의 쓰레드가 동작하려면 일정한 시간이 소요됩니다.

그래서 초반에는 커넥션을 조회하는 시간이 일부 지연될 수 있습니다.

이런 문제를 방지하기 위해 초반에는 메인 쓰레드에서 바로 커넥션을 생성하게 됩니다.

감사합니다.

 

저도 똑같이 메인 쓰레드에서 커넥션이 생성 되고 MyPool connection adder conn9 까지 생성 되었는데 이때 MyPool - After adding stats (total=10, active=2, idle=8, waiting=0) 이 부분이 포함이 안된 이유가 메인 쓰레드 생성된 커넥션도 개수로 포함이 되어서 그런건가요?

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

안녕하세요. 지루한 갈매기님

다음 링크를 참고해주세요^^

https://www.inflearn.com/questions/883581

태허키님의 프로필 이미지
태허키

작성한 질문수

질문하기