Christmas Pikachu 커넥션 풀(DBCP)
개발일지/JSP

커넥션 풀(DBCP)

ZI_CO 2022. 11. 29.

커넥션 풀(DBCP)란

데이터 베이스와 통신하는 자원을 효육적으로 관리하기 위한 기법

 

 

1

2

 

 

 

커넥션 풀(DBCP)을 사용하는 이유

자바에서 DB에 직접 연결해서 처리하는 경우(JDBC) 드라이버(Driver)를 로드하고 커넥션(connection) 객체를 받아와야 한다. 그러면 매번 사용자가 요청을 할 때마다 드라이버를 로드하고 커넥션 객체를 생성하여 연결하고 종료하기 때문에 매우 비효율적이다. 이런 문제를 해결하기 위해서 커넥션풀(DBCP)를 사용한다.

 

 

 

커넥션 풀(DBCP) 특징

  • 웹 컨테이너(WAS)가 실행되면서 connection 객체를 미리 pool에 생성해 둡니다.
  • HTTP 요청에 따라 pool에서 connection객체를 가져다 쓰고 반환한다.
  • 이와 같은 방식으로 물리적인 데이터베이스 connection(연결) 부하를 줄이고 연결 관리 한다.
  • pool에 미리 connection이 생성되어 있기 때문에 connection을 생성하는 데 드는 요정 마다 연결 시간이 소비되지 않는다.
  • 커넥션을 계속해서 재사용하기 때문에 생성되는 커넥션 수를 제한적으로 설정함

 

동시 접속자가 많을 경우

  • 위에 커넥션 풀 설명에 따르면, 동시 접속 할 경우 pool에서 미리 생성 된 connection을 제공하고 없을 경우는 사용자는 connection이 반환될 때까지 번호순대로 대기상태로 기다린다.
  • 여기서 WAS에서 커넥션 풀을 크게 설정하면 메모리 소모가 큰 대신 많은 사용자가 대기시간이 줄어들고, 반대로 커넥션 풀을 적게 설정하면 그 만큼 대기시간이 길어진다.

 

 

 

Commons DBCP 구조

속성 이름 설명
initialSize BasicDataSource 클래스 생성 후 최초로 getConnection() 메서드를 호출할 때 커넥션 풀에 채워 넣을 커넥션 개수
maxActive 동시에 사용할 수 있는 최대 커넥션 개수(기본값: 8)
maxIdle 커넥션 풀에 반납할 때 최대로 유지될 수 있는 커넥션 개수(기본값: 8)
minIdle 최소한으로 유지할 커넥션 개수(기본값: 0)

 

'개발일지 > JSP' 카테고리의 다른 글

JSP - 내장객체  (1) 2024.01.08
JDBC 사용방법  (0) 2022.11.29
DAO & DTO  (0) 2022.11.29
JSP - MYSQL 연결  (0) 2022.11.28
JSP - Cookie(쿠키)  (0) 2022.11.28

댓글