cubrid.jdbc.driver.CUBRIDException: Cannot allocate query entry any more. Maximum allocatable entries are 100

by ith posted Jan 06, 2025


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
CentOS8 64bit 
CUBRID Ver.
11.3
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
 

대량의 데이터를 많은 테이블( 사용자 및 계정, 관련 Log 테이블 )에 INSERT 및 UPDATE 하는 작업을 하는 테스트를 하고있습니다.

 

처음에는 정상 동작 하다가 어느 순간 

 

cubrid.jdbc.driver.CUBRIDException: Cannot allocate query entry any more. Maximum allocatable entries are 100.[CAS INFO-xx.xx.xxx.xxx:30000,49,1094373],[SESSION-175],[URL-jdbc:cubrid:xx.xx.xxx.xxx:30000:XXDB:XXX:********:].
    at cubrid.jdbc.jci.UConnection.createJciException(UConnection.java:1992)
    at cubrid.jdbc.jci.UInputBuffer.<init>(UInputBuffer.java:176)
    at cubrid.jdbc.jci.UConnection.send_recv_msg(UConnection.java:1854)
    at cubrid.jdbc.jci.UConnection.send_recv_msg(UConnection.java:1866)
    at cubrid.jdbc.jci.UStatement.executeInternal(UStatement.java:868)
    at cubrid.jdbc.jci.UStatement.execute(UStatement.java:954)
    at cubrid.jdbc.driver.CUBRIDStatement.executeCoreInternal(CUBRIDStatement.java:873)
    at cubrid.jdbc.driver.CUBRIDStatement.executeCore(CUBRIDStatement.java:839)
    at cubrid.jdbc.driver.CUBRIDPreparedStatement.executeUpdate(CUBRIDPreparedStatement.java:150)
 

이와 같은 오류가 발생합니다.

 

찾아보니  transaction당 사용할 수 있는 query수를 정해둔 것이라고 하던데 

 

cubrid broker info 를 통해 CCI_DEFAULT_AUTOCOMMIT이 on 처리도 되어있고

KEEP_CONNECTION은  AUTO, max_clients 은 500

MAX_PAN_CACHE_ENTRIES : 3000

MAX_QUERY_CACHE_ENTIRES : 3000

 

이렇게 설정했습니다.

 

혹시 다른 설정을 통해서 위의 상황에 대하여 처리 가능한 방안이 있을까요?

 

테스트는 멀티쓰레드로 동작합니다.

 


Articles

1 2 3 4 5 6 7 8 9 10