커넥션 생성 방식
399
작성한 질문수 8
DriverManagerDataSource를 사용하면 DriverManager를 통해 직접 DB에 접근해서 Connection을 획득하는 것으로 알고 있습니다.
HikariDataSource를 사용하면 ConnectionPool에서 얻어오는 것으로 알고 있습니다.
그리고 미리 ConnectionPool 내부의 DriverManager가 직접 DB에 접근해서 Connection을 획득한 후 ConnectionPool에 보관하는 것이 많나요?
맞다면 DrvierManagerDataSource나 HikariDataSource 모두 DB로부터 Connection을 직접 획득하는 주체는 DriverManager인거고 획득 방식은 동일한 것이 맞나요?
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
DriverManagerDataSource와 HikariDataSource는 모두 DataSource 인터페이스를 구현한 클래스입니다. 이 두 클래스는 애플리케이션과 DBMS 간의 커넥션을 관리합니다.
먼저 DriverManagerDataSource의 경우, DriverManager를 통해 직접 DB에 접근해 Connection 객체를 생성하는 것으로 알고 계셨습니다. 즉, DriverManagerDataSource는 애플리케이션과 DBMS 간에 직접 커넥션을 맺는 방식을 사용합니다.
반면에 HikariDataSource는 Connection Pool을 사용합니다. Connection Pool은 미리 여러 개의 Connection 객체를 생성하고, 필요할 때마다 해당 객체를 대여해줍니다. 이렇게 함으로써 Connection 객체를 생성하는데 드는 비용을 절감할 수 있습니다.
HikariCP는 Connection Pool 내부의 DriverManager가 직접 DB에 접근해서 Connection을 획득한 후 ConnectionPool에 보관합니다. 그러므로 DriverManagerDataSource나 HikariDataSource 모두 DB로부터 Connection을 직접 획득하는 주체는 DriverManager이며, 획득 방식은 동일합니다.
즉, 두 클래스 모두 DB에 직접 접근해서 Connection 객체를 획득하는 방식을 사용합니다. 다만, HikariDataSource는 Connection Pool을 사용해 최적화된 방식으로 커넥션을 관리합니다.
결론적으로, DriverManagerDataSource와 HikariDataSource는 모두 DB와의 커넥션을 생성하고 관리하는 역할을 수행하지만, 그 방식이 다릅니다.
추가적으로, HikariCP는 여러 기능들로 인해 성능이 우수하다고 알려져 있습니다.
도움이 되셨길 바랍니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
38
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
51
1
jdbc 학습하다 궁금해서 질문드려요
0
85
1
정상이체와 이체중 예외발생 차이
0
70
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
89
1
순수한 서비스 계층에 대한 의문???
0
83
2
3_4test, 4test 자동 리소스 안됨
0
60
2
데이터베이스 선택 관련 질문.
0
71
2
after 메서드 사용 유무
0
60
2
데이터베이스 접근 및 DB 락
0
57
1
@SpingBootTest, @TestConfiguration
0
58
1
Read Committed 격리 수준 사용 관련 질문
0
51
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
69
2
커리큘럼 관련 질문
0
78
1
서비서 계층 스프링 프레임워크 사용
0
89
1
validation(toMember)의 위치
0
84
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
166
2
member 상수 질문
0
124
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
154
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
110
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
103
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
98
1
강의 14분쯤 Exception 질문
0
116
2





