Background Image
Java
2008.11.21 18:31

DBCP 사용법

조회 수 48362 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

DBCP 설정 방법

소개: 아파치 DBCP(DataBase Connection Pool)을 통한 Statement 풀링(pooling) 사용 방법을 설명하고자 한다.

DBCP에서 Statement 풀링이 커넥션 별로 유지되고 있기 때문에, 응용서버(cas)에서는 질의를 컴파일 한 정보를 계속 유지하게 된다. 이 후 같은 질의에 대해서는 prepare 과정 없이 execute 단계만 반복함으로써 성능 향상을 가져올 수 있다.

이 문서에서 DBCP 설정 방법을 tomcat 사용 시와 일반 자바클래스 사용 시 두 가지 방법을 설명한다.

 

2008-10-15 기술컨설팅팀 손승일, CUBRID

적용 대상: CUBRID2008, JDK1.6.0_04 이상

DBCP Statement 풀링

DBCP Statement 풀링 기능을 사용하기 위해 브로커 파라미터에 STATEMENT_POOLING ON/OFF가 있다.

Statement 풀링이 사용되기 위해서는 DBCP 설정에서 poolPreparedStatements true로 설정되어야 하고, 브로커 설정에서 STATEMENT_POOLING ON으로 설정되어야 한다.

Statement 풀링을 사용할 경우는 DBCP와 브로커 둘 다 풀링을 사용하도록 설정되어 있어야 하고, 만약 어느 한 쪽만 설정한 경우는 오히려 성능이 떨어질 수 있다.

브로커 설정

CUBRID가 설치되어 있는 경로의 ~/CUBRID/conf/cubrid_broker.conf를 열어 연결에 사용될 브로커 하단에 STATEMENT_POOLING ON을 추가하고 브로커를 재 시작 하면 설정이 적용된다.

[%BROKER1]

SERVICE                 =ON

BROKER_PORT           =33000

SESSION_TIMEOUT       =300

KEEP_CONNECTION      = AUTO

STATEMENT_POOLING   =ON

DBCP 다운로드

DBCP를 사용하기 위해서는

commons-dbcp-1.2.2.jar  http://commons.apache.org/downloads/download_dbcp.cgi

commons-pool-1.3.jar http://commons.apache.org/downloads/download_pool.cgi

commons-collections-3.2.1.jar http://commons.apache.org/downloads/download_collections.cgi

에서 각각의 최신 릴리스 바이너리 파일을 다운 받아 압축을 풀면 위 파일들을 얻을 수 있다.

CUBRID JDBC Drivercubrid_jdbc.jar 파일은 CUBRID가 설치되어 있는 경로인 ~/CUBRID/jdbc/에서 얻을 수 있다.

Tomcat에서

위 세 파일과 CUBRID JDBC DriverCALTALIA_HOMEcommonlib 아래에 두고, CALTALIA_HOMEconfserver.xml을 아래와 같이 추가 설정한다.

server.xml

server.xml의 끝 부분에 존재하는 “</Host>” 위에 아래를 추가한다.

<Context docBase="C:DBTest" path="" reloadable="true">                  //1

 

<Resource name="jdbc/CUBRIDDS" auth="Container" type="javax.sql.DataSource" // 2

 factory="org.apache.commons.dbcp.BasicDataSourceFactory"

 driverClassName="cubrid.jdbc.driver.CUBRIDDriver"            // 3

 url="jdbc:cubrid:localhost:33000:demodb:::"  // 4

 username="public" password=""   // 5

 initialSize="10"

 maxActive="10"

 maxIdle="10"

 maxWait="-1"

 poolPreparedStatements="true"/> // 6

</Context>

·      1: 루트 디렉토리를 설정하는 부분으로 예제에서는 C:DBTest (Unix/Linus /DBTest) 디렉토리를 생성하고 이곳을 루트 디렉토리로 설정한다. 이곳에 jsp 등 관련 파일이 위치하면 된다.

·      2: JNDI name으로 임의로 사용 할 이름을 입력 한다.

·      3: JDBC 드라이버 클래스 이름으로 cubrid.jdbc.driver.CUBRIDDriver 를 입력하면 된다.

·      4: 접속 할 데이터베이스 urljdbc:cubrid:IP:PORT:DB이름::: 형식으로 입력한다.

IP : 데이터베이스가 있는 서버 IP

PORT : 큐브리드 브로커의 포트(default : 33000)

DB이름 : 데이터베이스 이름

·      5: 데이터베이스에 접속할 아이디.  기본적으로 데이터베이스에는 DBA PUBLIC 2개의 아이디가 존재한다.  ID 파라미터에 아무 것도 입력하지 않고 “”를 입력하면 기본적으로 PUBLIC 아이디로 데이터베이스에 접속한다. 앞에서 사용한 아이디에 암호가 설정되어 있다면 PASSWORD 파라미터를 입력한다.  없다면 그냥 “”를 입력한다.

·      6: Statement 풀링이 사용되기 위한 설정으로 true로 설정해야 한다.

간단예제

아래 소스를 CALTALIA_HOMEconfserver.xml <Context docBase="C:DBTest" path="" reloadable="true"> 부분에 설정한 루트 디렉토리에 작성한다.

<%@ page contentType="text/html; charset=euc-kr"%>

<%@ page import="java.util.*" %>

<%@ page import="java.sql.*" %>

<%@ page import="javax.sql.*" %>

<%@ page import="javax.naming.*" %><%//1%>

<%

    Connection conn = null;

    PreparedStatement pstmt = null;

    ResultSet rs = null;

    try {

// 큐브리드 DB Connect하기 위해서 JNDI를 통해 DataSourse를 가져온다.

        Context initContext = new InitialContext();                //2

        DataSource ds = (DataSource) initContext.lookup("java:comp/env/jdbc/CUBRIDDS");     //3

              conn = ds.getConnection();                    //4

              String sql = "select name from nation";                                                                                                                                                                                     

              pstmt = conn.prepareStatement(sql);

              rs = pstmt.executeQuery();

              while(rs.next()) {

                        out.println("name ==> " + rs.getString(1));

                    out.println("<br>");

              }

      } catch ( SQLException e ) {

              System.err.println(e.getMessage());

      } catch ( Exception e ) {

              System.err.println(e.getMessage());

      } finally {

          try{

                                       if ( rs != null ) rs.close();

              }catch( Exception e ) {}

              try{

                                     if ( pstmt != null ) pstmt.close();

              }catch( Exception e ) {}

              try{

                                         if ( conn != null ) conn.close();

              }catch( Exception e ) {}

      }

%>

·      1: Connection Pool을 이용한 DB Connection JNDI를 통해 DataSourse를 가져오고 DataSourse를 통해 DB Connection하게 되는데, 이 때 Contex DataSource를 사용하기 위해서 javax.naming.* javax.sql.* import 해준다.

·      2: JNDI name으로 임의로 사용 할 이름을 입력 한다.

·      3: JNDI를 통해 DataSource를 가져오는데 DataSource ds = (DataSource) initContext.lookup("java:comp/env/jdbc/CUBRIDDS"); 와 같이 server.xml Resource name에 설정된 값 앞에 java:comp/env/를 붙여서 사용한다.

·      4: DataSource를 통해 DB Connection한다.

위 예제 파일명이 dbcp_test.jsp로 가정하고 예제 실행을 위해 웹페이지를 http://localhost:8080/dbcp_test.jsp 또는 http://<설치한서버의주소>:8080/dbcp_test.jsp 로 접속하면 결과를 볼 수 있다.

Java class에서

DBCP 사용을 위한 세 파일과 CUBRID JDBC Driverclasspath에 설정한다.

ConnectionManager.java

DBCP 를 생성하고 Connection을 제공하는 역할을 한다.

import java.sql.*;

import org.apache.commons.dbcp.BasicDataSource;            // 1

public class ConnectionManager {

    private BasicDataSource ds = null;

// DBCP를 생성한다.

    private void setupDataSource() {       

        if (ds == null) {

            ds = new BasicDataSource();            

            String url = "jdbc:cubrid:localhost:33000:demodb:::";

            String className = "cubrid.jdbc.driver.CUBRIDDriver";

            String userName = "public";

            String passWord = "";

            ds.setDriverClassName(className); // 2

            ds.setUrl(url);                  // 3

            ds.setUsername(userName);             // 4

            ds.setPassword(passWord);             

            ds.setMaxActive(10);

            ds.setInitialSize(10);

            ds.setMinIdle(5);

            ds.setMaxWait(5000);

            ds.setPoolPreparedStatements(true);                   // 5

        }

    }

// BasicDataSource로부터 connection을 얻어온다.

    public Connection getConnection() throws SQLException {

        setupDataSource();

        return ds.getConnection();  // 6

    }

}

·      1: BasicDataSource을 사용하기 위해 org.apache.commons.dbcp.BasicDataSource import 시켜준다.

·      2: JDBC 드라이버 클래스 이름으로 cubrid.jdbc.driver.CUBRIDDriver 를 입력하면 된다.

·      3: 접속 할 데이터베이스 urljdbc:cubrid:IP:PORT:DB이름::: 형식으로 입력한다.

IP : 데이터베이스가 있는 서버 IP

PORT : 큐브리드 브로커의 포트(default : 33000)

DB이름 : 데이터베이스 이름

·      4: 데이터베이스에 접속할 아이디.  기본적으로 데이터베이스에는 DBA PUBLIC 2개의 아이디가 존재한다.  ID 파라미터에 아무 것도 입력하지 않고 “”를 입력하면 기본적으로 PUBLIC 아이디로 데이터베이스에 접속한다. 앞에서 사용한 아이디에 암호가 설정되어 있다면 PASSWORD 파라미터를 입력한다.  없다면 그냥 “”를 입력한다.

·      5: Statement 풀링이 사용되기 위한 설정으로 true로 설정해야 한다.

·      6: BasicDataSource로 부터 connection을 얻어온다.

execDBCP.java

ConnectionManager를 이용하여 connection을 얻어오고 질의를 수행한다.

import java.sql.*;

public class execDBCP{ 

              public static void main(String args[]){

              Connection conn = null;                         

              PreparedStatement pstmt=null;

              ResultSet rs =null;

              String query = "select name from nation";

              try {

                                         ConnectionManager cm = new ConnectionManager();

                                         conn = cm.getConnection();             //1                                                      

                                         pstmt = conn.prepareStatement(query);

                                         rs = pstmt.executeQuery();

                                         while(rs.next()){

                                                             System.out.println("result=>"+rs.getString(1));

                                         }

                                         rs.close();

                                         pstmt.close();                                                         

              } catch (Exception e) {

                                         e.printStackTrace();

              }finally {

                                         if(rs != null) try { rs.close(); } catch(Exception e) {}

                                      if(pstmt != null) try { pstmt.close(); } catch(Exception e) {}

                                     if(conn != null) try { conn.close(); } catch(Exception e) {}

              }                                             

              }

}

·      1: ConnectionManager을 생성하고 getConnection을 호출하여 DBCP로 부터 connection을 얻어온다.  

  • ?
    성진 2015.07.10 01:51

    tomcat 버전 업 하면서 dbcp pool기능이 들어갔습니다.

    톰켓 7.0 설치 디렉터리의 lib 폴더에 tomcat-dbcp.jar가 포함 되어 있습니다.

    또한 context 설정이 따로 파일이 분리 되어 context.xml이 존재 합니다.


    따라서 context.xml 파일을 다음과 같이 수정 하시고  factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 

    클래스 위치 변경 됨


    <Context>

    <Resource name="jdbc/CUBRIDDS" auth="Container" type="javax.sql.DataSource"

      factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"

          driverClassName="cubrid.jdbc.driver.CUBRIDDriver"

          url="jdbc:cubrid:localhost:33000:demodb:::" username="dba" password="dbpw"

          maxActive="10" maxIdle="10" maxWait="-1" />

    </Context>


    web.xml에 리소스 레퍼 추가

    <resource-ref>

    <description>CUBRID</description>

    <res-ref-name>jdbc/CUBRIDDS</res-ref-name>

    <res-type>javax.sql.DataSource</res-type>

    <res-auth>Container</res-auth>

    </resource-ref>


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
46 튜닝 [질의튜닝]order by desc가 인덱스 타게 하려면 admin 2011.07.14 28456
45 튜닝 CUBRID 2008 R4.0의 커버링 인덱스(covering index)는 무엇인가? file admin 2011.07.14 29880
44 튜닝 SNS 유형 서비스에서 CUBRID와 MySQL 조회 성능 비교 file admin 2011.07.14 21187
43 기타 CUBRID 볼륨 공간 재사용률 비교 - 2008 R3.1 vs. 2008 R4.0 file admin 2011.07.14 16554
42 기타 CUBRID 2008 R4.0 파라미터 변경 사항 (일부) file admin 2011.07.14 13154
41 기타 CUBRID 2008 R4.0 GA 버전의 주요 기능만 요약한 PPT 문서 file admin 2011.07.14 15460
40 기타 동시 접속자에 따른 파라미터 설정 admin 2011.07.14 25680
39 기타 CUBRID 매니저 R3.1에서 웹호스팅 서버의 CUBRID R2.1 접속하는 방법 (큐브리드 매니저에서 다른 버전의 큐브리드 서버 접속 방법) file admin 2011.07.14 31507
38 기타 [주의사항] CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점 admin 2011.07.14 52553
37 기타 자주 발생하는 큐브리드(cubrid) 에러 메시지 정리 admin 2011.07.14 81364
36 Install CUBRID Ubuntu Launchpad Installation 방법 file 정만영 2011.07.19 29604
35 Install LINUX CUBRID 4.0 매니저 설치방법 file 정만영 2011.07.19 23653
34 기타 select .. for update 처리를 위한 Stored Procudure 등록 및 사용법 남재우 2011.12.10 24870
33 Install CUBRID기반으로 XE 운영하기 – 설치가이드 file cubebridge 2012.04.13 30929
32 Java CUBRID와 Oracle의 Clob 타입 사용 방법 비교. seongjoon 2012.06.30 54548
31 ODBC/OLEDB VB에서 CUBRID ODBC/OLEDB 사용하는 방법 및 샘플코드. file seongjoon 2012.06.30 26917
30 기타 HA 환경 구성 시 데이터 복제 지연이 발생하는 경우 ECHO(7) port를 확인하자. 손승일 2012.11.29 26440
29 PHP Apache, PHP 설치 방법 file 이용미 2013.05.16 41246
28 PHP phpize를 이용한 PHP 모듈 연동 방법(CUBRID2008 R4.3 버전) file 이용미 2013.05.16 20853
27 Linux CUBRID Linux 부팅시 자동시작 서비스 설정 방법 정만영 2013.09.16 25454
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales