Background Image
조회 수 40190 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

CUBRID Java Stored Procedure DB Server Memory 관계

소개: CUBRID Java Stored Procedure(이하 JSP)를 사용하는 중 java.lang.OutOfMemoryError: unable to create new native thread 라는 오류가 발생하는 경우 원인을 파악하기 위해 JSP DB Server Memory의 관계를 알아보고, 해결 방법을 제시하고자 한다.

 

JSP DB Server Process 관계

JSP DB Server Process와의 관계를 먼저 간단히 설명하겠다.

JSP를 사용하기 위해 CUBRID 설정 파일인 cubrid.confjava_stored_procedure=yes로 설정한 후 cubrid server start를 수행하면 DB Server Process JVM을 포함하여 함께 구동된다. 이때부터 CUBRID JSP를 사용할 수 있는 환경이 구성되는 것이다.

다음은 수행하고자 하는 로직을 java로 작성하여 compile 한 후 loadjava를 수행하여 DB Server에 로딩하고, DB에 해당 클래스를 사용할 수 있도록 등록해준다.(자세한 사용법은 매뉴얼 CUBRID SQL 설명서 > Java 저장 함수/프로시저 부분 참고)

여기까지 완료되고 나면 JAVA 프로그램이나, CUBRID Manger를 통해 JSP를 요청하게 되는데, 이 요청을 받은 Broker는 가용한 cas에게 작업을 할당하게 되고, cas DB Server process에 포함되어 있는 JVM 내부에 JSP thread를 생성한다.

따라서 JVM JSP thread는 최대 MAX_NUM_APPL_SERVER(cubrid_broker.conf)에 설정되어 있는 값만큼 생성된다.

JSP DB Server Memory관계

지금부터는 이 문서에서 다루고자 하는 JSP DB Server Memory관계를 설명하고, OutOfMemoryError이 발생하는 원인을 설명하도록 하겠다.

DB Server가 사용하는 Memorydata buffer, log buffer 등 데이터 처리를 위해 사용하는 부분과 JVM이 사용하는 부분으로 구분할 수 있다.

위에서 JSP가 요청되면 JVM 내부에 thread가 생성된다고 하였다. thread JVM Memory영역 중 Stack 영역에 Java Stack을 생성한다.

아래는 이것을 간단히 도식화한 그림이다.



“java.lang.OutOfMemoryError: unable to create new native thread” JVM Java Stack을 생성해야 하는데 Memory가 부족하여 Java Stack를 생성하지 못하여 thread도 생성하지 못하여 발생하는 오류이다.

이것은 경우에 따라 세 가지로 구분해볼 수 있고, 해결 방법은 아래와 같다.

1.     JSP로 사용될 JAVA Program에서 메모리 누수가 발생하여, Heap 영역에 리소스가 부족하게 되고, Stack 생성에 필요한 Heap 영역 리소스 확보가 안 되는 경우

è JAVA Program에서 메모리 누수가 발생하는 부분을 해결한다.

2.     JVM에 할당된 Memory를 넘는 Java Stack 생성을 요청한 경우

è 이러한 경우 JVM thread stack 사이즈를 줄여 주면 생성될 수 있는 Java Stack의 개수가 늘어난다.

설정 방법 : ex) .bash_profile export _JAVA_OPTIONS=”-XX:ThreadStackSize=128

è Heap 영역의 사이즈를 줄여 Stack영역에서 더 많이 사용할 수 있게 한다.

설정 방법 : ex) .bash_profile export _JAVA_OPTIONS=”-Xmx512m

3.     32bit OS Process 별 메모리 사용한도인 3G를 넘는 Memory를 사용하려 하는 경우

è DB Server process 메모리에 영향을 주는 data_buffer_pages 값을 줄여 준다.

설정 방법 : $CUBRID/conf/cubrid.conf data_buffer_pages 값을 변경하고, cubrid server restart db_name 을 수행

è 1번의 두 번째처럼 Heap 영역의 사이즈를 줄여 준다.

è MAX_NUM_APPL_SERVER를 줄여 JSP 요청을 줄여 준다.

설정 방법 : $CUBRID/conf/cubrid_broker.conf의 해당 브로커의 MAX_NUM_APPL_SERVER의 값을 변경하고, cubrid broker restart broker_name을 수행.

TAG •

  1. 자주 발생하는 큐브리드(cubrid) 에러 메시지 정리

    Date2011.07.14 Category기타 Byadmin Views81444
    Read More
  2. 리눅스에서 top 명령어를 통한 CPU 점유율 확인 및 측정하기

    Date2017.06.02 CategoryLinux By정훈 Views80816
    Read More
  3. CUBRID와 Oracle의 Clob 타입 사용 방법 비교.

    Date2012.06.30 CategoryJava Byseongjoon Views54562
    Read More
  4. iBATIS framework with CUBRID

    Date2009.05.19 CategoryJava By웁쓰 Views54549
    Read More
  5. HP-UX에서 CUBRID 사용을 위한 kernel 설정값 조정

    Date2009.04.01 CategoryLinux Byadmin Views54152
    Read More
  6. Spring framework 사용 예제

    Date2009.04.01 CategoryJava Byadmin Views53135
    Read More
  7. [주의사항] CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점

    Date2011.07.14 Category기타 Byadmin Views52796
    Read More
  8. connect by 구현 방법

    Date2009.04.01 Category기타 Byadmin Views52375
    Read More
  9. windows 상에서 PHP 설치하기

    Date2008.11.21 CategoryPHP Byadmin Views51804
    Read More
  10. 오라클 개발자를 위한 CUBRID 개발 안내

    Date2009.04.01 Category기타 Byadmin Views49822
    Read More
  11. DBCP 사용법

    Date2008.11.21 CategoryJava Byadmin Views48373
    Read More
  12. CUBRID 2008 사용법

    Date2008.11.21 CategoryWindows Byadmin Views47939
    Read More
  13. jsp용 jdbc 샘플입니다.

    Date2009.05.25 CategoryJava By시난 Views47609
    Read More
  14. CUBRID 활용 - 질의 튜닝 사례 중심

    Date2010.12.02 Category기타 Bycubrid Views45962
    Read More
  15. CUBRID에서 log4sql을 사용하자

    Date2009.06.12 CategoryJava By정병주 Views44305
    Read More
  16. Windows 에서 CUBRID 설치하기

    Date2008.11.22 CategoryInstall By남재우 Views43645
    Read More
  17. LINUX에서 PHP 사용하기

    Date2008.11.21 CategoryPHP Byadmin Views42495
    Read More
  18. CUBRID Manager 사용시 로그인에 대하여

    Date2009.04.01 CategoryInstall Byadmin Views42046
    Read More
  19. Apache, PHP 설치 방법

    Date2013.05.16 CategoryPHP By이용미 Views41248
    Read More
  20. CUBRID 개발 로드맵

    Date2008.12.27 Category기타 Byadmin Views40321
    Read More
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