본문 바로가기
IT/Knowledge

Hikari 커넥션풀(connection pool)

by 성준하이 2023. 1. 31.
반응형

Hikari Connection Pool

HikariConnection Pool (이하 Hikari CP)은 DB와의 커넥션 풀을 관리한다.

이유는 JDBC커넥션을 맺는 과정은 상당히 복잡하고 자원을 많이 소모하는 작업이기 때문에 관리를 해야 성능적으로 좋기 때문이다. 

만약 요청이 들어올 때 Thread가 Database와의 커넥션을 맺는다면 데이터베이스 뿐만 아니라 앱서버 입장에서도 굉장히 부하가 심하게 발생 할 것이다. 그런데 HikariCP는 미리 정해놓은 만큼에 커넥션은 pool에 담아 놓는다. 요청이 들어오면 Thread가 커넥션을 요청하고, Hikari는 Pool내에 있는 커넥션을 연결해준다.

Connection Pool ( 커넥션 풀 )

데이터 연동과정에서 일반적인 연동과정은 웹 어플리케이션이 필요할 때마다 데이터베이스에 연결하여 작업하는 방식이다. 그런데 이런 식으로 필요할 때마다 연동해서 작업할 경우 데이터베이스 연결에 시간이 많이 걸린다는 문제가 있다. 이 문제를 해결하기 위해 현재는 웹 어플리케이션이 실행됨과 동시에 연동할 데이터베이스와의 연결을 미리 설정해 두고, 필요할 때마다 미리 연결해 놓은 상태를 이용해 빠르게 데이터베이스와 연동하여 작업을 한다. 이 작업을 Connection Pool이라고 한다.

메커니즘

유의점

DB에서는 기본적으로 커넥션을 일정량 제공해주는데 유저가 많아져서 커넥션이 모자랄 경우, 원할한서비스가 이루어지지 않는다. 커넥션이 반납될때까지 기다려야 하기 때문이다. 따라서 유저수에 따라 커넥션을 조절할 필요가 있다

반응형

'IT > Knowledge' 카테고리의 다른 글

netstat  (9) 2023.02.02
netsh 란?  (7) 2023.02.01
overflow 란?  (9) 2023.01.25
도커라이징 이란?  (10) 2023.01.19
nvm이란?  (8) 2023.01.18

댓글