Java

Java에서 DB를 연결하는 2가지 방법과 DBCP를 사용하는 이유

dev_SiWoo 2022. 1. 7. 16:34

1) JDBC를 사용하는 방법

오라클이던, MySQL이던 각 DB에서 제공하는 DB Connection API를 이용해서 DB에 접속하는 방법이다.

사용자가 직접 소스코드에 ID와 PassWord, IP 등을 입력하여 커넥션 객체를 생성하고 그 객체를 이용해서 DB를 제어하는 방법이다.

 

2) Connection Pool( DBCP : DataBaseConnectionPool )을 사용하는 방법

  사용자(프로그래머)가 소스에서 직접 DB에 연결하는 것이 아니라, 연결은 WAS(톰켓,제우스 같은)가 하고 사용자는 WAS가 연결한 커넥션을 이용하는 방법이다. 

 

웹 컨테이너(WAS)가 실행되면서 DB와 미리 connection을 해놓은 객체들을 pool에 저장해두었다가

클라이언트 요청이 오면 connection을 빌려주고, 처리가 끝나면 다시 connection을 받납받아서 pool에 저장하는 방식이다.

 

- WAS가 실행되면서 connection 객체를 미리 pool에 생성해 두기 때문에 connection을 생성하는데 드는 요청마다 연결시간이 소비되지 않는다는 장점이 있다.

 

- 커넥션을 계속해서 재사용하기 때문에 생성되는 커넥션 수를 제한적으로 설정한다.

 

 

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

JSP에 대해서 공부했거나 프로젝트를 해봤던 사람이라면 다음과 같은 소스를 본적 있을 것이다.

package java_arguments.JDBC_test;
import java.sql.*;

public class DB_Connection {

    static final String DRIVER =  "org.mariadb.jdbc.Driver";
    static final String URL = "jdbc:mariadb://localhost:3306/test_db";
    static final String USER = "root";
    static final String PASSWORD = "testdb";

    Connection con;
    PreparedStatement pstmt;
    ResultSet rs;

    public DB_Connection(){
        try{
            Class.forName(DRIVER);
            con = DriverManager.getConnection(URL, USER, PASSWORD);
            if( con!= null){
                System.out.println("DB 접속에 성공했습니다.");
            }

        } catch (ClassNotFoundException e){
            System.out.println("드라이버 로드 실패");
        } catch (SQLException e){
            System.out.println("DB 접속실패");
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
        DB_Connection new_db = new DB_Connection();
    }
}

위와 같이 자바에서 DB에 직접 연결해서 처리하는 경우 JDBC 드라이버를 로드한 이후

커넥션 객체를 받아와야 한다. 

 

하지만 이렇게 직접 연결해버릴 경우 매번 사용자가 요청할 때 마다 드라이버를 로드하고 커넥션 객체를 생성하여 

연결하고 종료하기 때문에 매우 비효율적이다.

 

이러한 문제를 해결하기 위해서 커넥션풀(DBCP)를 사용한다.

 

#동시 접속자가 많을 경우

 Connection Pool 설명에 따르면 동시 접속 할 경우 pool에서 미리 생성된 conenction을 제공하고 없을 경우에는 

connection이 반환될 때까지 번호순대로 대기 상태로 기다린다.

 

또한 WAS에서 커넥션 풀을 크게 설정하면 메모리 소모가 큰 대신 많은 사용자가 대기시간 없이 사용할 수 있지만 반대로 커넥션 풀을 적게 설정하면 그만큼 대기시간이 길어질 수 있다.