• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

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

23.04.01 03:39 작성 조회수 389

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

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

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

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

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

감사합니다.

 

지루한 갈매기님의 프로필

지루한 갈매기

2023.06.26

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

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

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

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