Background Image
응용개발
2016.12.14 21:22

CUBRID 와 DBCP의 관계

조회 수 2787 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

JDBC는 응용프로그램을 개발할 때 질의를 실행할 때마다 서버와 새로운 연결을 맺는 대신 연결 풀(Connection pool)을 만들어두고

필요할 때 연결하거나 이미 연결된 연결 객체를 재사용해 응용프로그램의 성능을 높이는 방법을 이용한다.


큐브리드는 DBCP등의 연결 풀 설정이 다른 DBMS와 다소 다르다.

큐브리드는 3계층으로 구성되어 있으며 그 가운데 브로커(CAS)가 있다. 브로커는 DB서버와 연결을 맺은 CAS를 cubrid_broker.conf파일에

지정된 개수만큼 유지하면서 응용프로그램에서 요청할 때마다 CAS를 할당해주고 다시 반납받는 구조로 되어 있다.

즉,  자체 연결 풀을 관리한다고 볼 수 있다.


그러므로, 큐브리드에서는 브로커가 DB와의 연결 상태를 계속 관리하기 때문에 DBCP의 연결 검증을 별도로 실행하지 않아도 된다.


일반적으로 연결 풀에 있는 연결을 검증하기 위해 가벼운 질의를 주기적으로 실행하는 방식으로 사용하는데,

DBCP는 ValidationQuery 설정에 SELECT 1과 같이 지정한다. 그에 비해 큐브리드는 드라이버와 브로커간에 상호 연동하며 자동으로

연결을 유지하기 때문에 VaildationQuery 설정이 의미가 없을 뿐만 아니라. VaildationQuery를 설정하는 경우 무의미한 연결 검증

때문에 브로커에 자꾸 연결을 요청하느라 정작 응용프로그램에 필요한 연결이 늦어질 수 있다.


그래서 ValidationQuery의 수행과 관련된 다음의 DBCP 옵션은 모두 비활성화하는 것이 큐브리드 응용프로그램의 성능을 향상하는데

도움이 된다.

TestOnBrrow=false

TestOnReturn=false

TestWhileIdle=false


DBCP가 아닌 JDBC연결 객체를 관리하는 다른 라이브러리를 사용하는 경우에도 연결을 검증하는 부분을 비활성화하는 것이 좋다.

( WAS서버 : JBOSS, Tomcat )


DB에 동시 연결할 수 있는 응용프로그램의 최대 개수는 DBCP의 maximumActiveConnection값으로 설정한다.

응용프로그램은 큐브리드의 CAS 프로세스를 통해 DB에 연결하는데 동시에 구동될 수 있는 CAS 프로세스의 최대 개수를

cubrid_broker.conf파일의 MAX_NUM_APPL_SERVER 파라미터로 설정한다.

따라서 DBCP의 maximumActiveConnection 설정값이 MAX_NUM_APPL_SERVER 파라미터로 설정값을 초과하지 않아야 한다.


예를 들면 MAX_NUM_APPL_SERVER 파라미터 설정값이 200 이고, WAS서버가 2대 인 경우

DBCP의 maximumActiveConnection 설정값 100을 넘지 않는 것이 좋다.


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
56 응용개발 CUBRID PHP 드라이버 빌드와 연동방법 정만영 2018.03.07 3759
» 응용개발 CUBRID 와 DBCP의 관계 엄기호 2016.12.14 2787
54 응용개발 Windows 환경에서 JAVA SP 사용 utf-8 한글 깨짐 해결 file 손승일 2016.07.01 4592
53 응용개발 Windows에서 32bit 버전의 PHP 설치 후 CUBRID와 연동 실패 시 해결 방법 file 진우진 2016.03.28 4523
52 응용개발 CUBRID DB에서 critical section 정보 출력하기 file 주현 2015.12.31 4578
51 응용개발 CUBRID HA 제약 사항 및 확인 방법 손승일 2015.12.29 5302
50 응용개발 maven에서 CUBRID JDBC Driver 추가하기 file 김승훈 2015.12.09 8929
49 응용개발 WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis) 1 이상신 2015.08.21 55119
48 응용개발 JAVA SP 사용 시 로그 처리 방법 손승일 2015.06.03 8571
47 응용개발 전체 레코드 개수 확인하는 SP 김승훈 2015.05.07 14721
46 응용개발 CUBRID-PHP-Driver 연동가이드 file cubebridge 2012.11.13 17136
45 응용개발 오라클 to CUBRID로 마이그레이션 수행 시 주의사항 cubebridge 2012.11.12 16640
44 응용개발 utf-8로 저장된 한글이 JAVA SP를 사용하여 읽어 오면 깨져 보일때 손승일 2012.03.10 20795
43 응용개발 Weblogic 10.0 사용시 JDK 1.5를 사용한 JDBC 드라이버 사용시 주의사항. cubebridge 2012.02.22 51957
42 응용개발 CUBRID에서 SQL힌트와 주석을 쓸 때 순서. cubebridge 2012.01.11 13321
41 응용개발 CUBRID R3.0부터 JDBC를 사용하는 응용에서 charset 설정 방법이 변경되었네요. 손승일 2010.12.02 19634
40 응용개발 CUBRID와 Oracle에서의 ''(공백)의 차이 비교 cubebridge 2010.10.01 28583
39 응용개발 cubrid-php module r2.2 이상 버젼에서 configure시에 주의사항 seongjoon 2010.07.20 14007
38 응용개발 CUBRID에서 CHAR와 NCHAR의 차이점 cubebridge 2010.07.01 21319
37 응용개발 PHP에 CUBRID 모듈 추가시 모듈이 로드되지 않는 문제에 대한 해결 방안 하나입니다 남재우 2010.07.01 16557
Board Pagination Prev 1 2 3 Next
/ 3

Contact Cubrid

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