inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

커넥션 풀에서 타임아웃 관련 질문

283

jihun4178

작성한 질문수 4

1

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
안녕하세요 영한님 강의 수강생입니다.
 
다음이 아니라 커넥션 풀에 대한 강의를 듣다가 질문이 생겼습니다.
 
질문1)
강의에서는 커넥션 풀의 커넥션들은 이미 연결이 된 상태로 존재한다고 들었는데, 만약 커넥션을 필요로 하는 요청이 오지 않고 계속해서 커넥션 풀에 커넥션이 남아있게 된다면, TCP 타임아웃이 발생하여 커넥션이 만료될텐데, 이럴 경우에는 어떻게 처리가 되는지 궁금합니다.
 
히카리에서 TCP 타임아웃이 발생한 커넥션을 다시 살려놓거나 아니면 JDBC 드라이버 단에서 알아서 다시 살려놓을수도 있겠다는 생각을 해봤습니다.
 
질문2)
커넥션 풀에서 커넥션을 받아 쿼리를 수행하던 도중에, TCP 커넥션이 만료된다면 어떤 상황이 발생하는지 궁금합니다.
 
감사합니다.

spring

답변 1

1

김영한

안녕하세요. jihun4178님

질문1

DB 커넥션 풀 마다 이런 부분을 체크하는 로직이 다릅니다. 주기적으로 이런 부분을 백그라운드에서 체크하는 풀도 있습니다. 히카리의 경우 새로운 커넥션 획득 요청이 있을 때 해당 커넥션의 TCP 연결이 살아있는지, 내부에서 DB에 요청을 보내서 한번 체크하게 됩니다. (참고로 수 초 이내에 이미 사용했던 커넥션을 다시 획득하는 경우에는 이미 검증되었다고 보고 그대로 커넥션을 사용하게 됩니다.)

질문2

쿼리를 수행하는 도중에 TCP 연결이 끊어지게 되면 결과를 받지 못하고 오류가 발생합니다.

hikaricp에 대한 더 자세한 내용은 hikaricp 최적화로 검색해보시면 원하시는 자료를 찾으실 수 있을거에요^^

감사합니다.

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

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