Background Image

FORUM

조회 수 110 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
CENTOS7
CUBRID Ver.
CUBRID 10.1 (10.1.27694-63632b2) 64bit
CUBRID TOOL Ver.
CUBRID Manager 10.1.0.000
응용 환경(API)
java(jdk 1.8.0_212)

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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


안녕하세요.

현재 컨트롤러 단에서 dba 권한으로 큐브리드 데이터베이스에 접속 후, 

새로운 데이터베이스를 생성, 계정을 만들고 

새로 생성한 계정으로 Connection하여 특정 경로에 있는 xml문서의 데이터를 파싱, 테이블을 만들고 데이터를 insert 하는 과정을 처리중입니다. 

create table 과 insert data 를 반복하며, 잘 진행되다가 insert data 양이 약 10,000건 이상인 테이블을 생성할 경우,

Cannot communicate with the broker 에러가 발생합니다. 


찾아보니 cubrid_broker.conf 설정에서 session_timeout 을 바꿔주면 된다는 글을 확인하여

--------------------------------------------------------------------------------------------------------------------------------

[broker]

MASTER_SHM_ID           =30001

ADMIN_LOG_FILE          =log/broker/cubrid_broker.log


[%query_editor]

SERVICE                 =ON

BROKER_PORT             =30000

MIN_NUM_APPL_SERVER     =5

MAX_NUM_APPL_SERVER     =200

APPL_SERVER_SHM_ID      =30000

LOG_DIR                 =log/broker/sql_log

ERROR_LOG_DIR           =log/broker/error_log

SQL_LOG                 =ON

TIME_TO_KILL            =120

SESSION_TIMEOUT         =1h

KEEP_CONNECTION         =AUTO

CCI_DEFAULT_AUTOCOMMIT  =ON



[%BROKER1]

SERVICE                 =ON

BROKER_PORT             =33000

MIN_NUM_APPL_SERVER     =5

MAX_NUM_APPL_SERVER     =200

APPL_SERVER_SHM_ID      =33000

LOG_DIR                 =log/broker/sql_log

ERROR_LOG_DIR           =log/broker/error_log

SQL_LOG                 =ON

TIME_TO_KILL            =120

SESSION_TIMEOUT         =1h

KEEP_CONNECTION         =ON

--------------------------------------------------------------------------------------------------------------------------------

위와 같이 설정을 바꿔주었습니다. 
변경 후에는 만건 이상 데이터는 처리가 됩니다.
그런데 한 테이블에 데이터가 870만건인 테이블이 존재하여 설정한 session_timeout 의 1h 으로 부족할 것 같은데 
혹시 무한대로 설정할 수 있는 방법은 없나요? 아니면 최대 설정 시간을 알고싶습니다. 
-1  으로 설정하였더니 broker start fail 이 뜹니다. 

아니면 추가적으로 이렇게 많은 데이터의 마이그레이션 처리 시 활용할 수 있는 방법이 있을까요? 
현재 insert 는 배치를 사용 중입니다. 

stmt.addBatch(insertSql);       
if( count % 1000 == 0 ){
stmt.executeBatch(); // Batch execute
        stmt.clearBatch(); // Clear
        conn.commit();
}
        
if(count != 1){
    stmt.executeBatch();
    conn.commit();
}


  • ?
    오명환 2020.03.24 08:49
    session timeout은 주어진 시간동안 어떤 요청이 들어오지 않는 경우 발생하는 타임아웃입니다.
    즉, 설정값이전에 지속적으로 작업을 수행하면 timeout는 발생하지 않습니다.
    그리고, 무한대로 설정하는 방법은 제공되지 않습니다.

    Cannot communicate with the broker 에러는 timeout만 아닌 network 오류 또는 해당 broker down되어 있는 경우에 발생할 수 있습니다.
    DB서버의 $CUBRID/log/broker 아래의 로그들을 확인해보시는 에러의 원인을 찾는데 도움이 될 것 같네요.
    error_log는 오류발생한 내역,
    sql_log는 수행된 질의 로그가 connection별 시간별로 남겨져 있습니다.
  • ?
    박세훈 2020.03.24 10:58
    첨부해주신 addBatch관련 소스는 session timeout과는 관련이 없어 보입니다.

    위에 설명처럼 session timeout은 DB에 요청이 없는 순간부터 시간을 측정하여 그 시간이 넘게 되면 세션을 끊습니다.
    아마도 xml문서의 데이터를 파싱하는데 시간이 많이 걸리는 것으로 생각이됩니다.
    이 작업동안에 DB 요청이 없을 것으로 생각되는데, 가능하다면 작업 이전에 commit을 넣어보세요.
    select만 있더라도 트랜잭션의 시작으로 인식하기 때문에 commit을 넣어야 DB 작업 이외의 작업시간과 무관하게 작업 하실 수 있습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 478
3139 COUNT 함수 1 file 현수 2020.05.06 66
3138 HA 구성시 MASTER 서버 접속 실패 상황 1 nagh 2020.05.06 103
3137 큐브리드 매니저 연결시 - 빈번하게 remote host closed connection during handshake 이란 오류가 발생 합니다. 6 마이클 2020.05.06 412
3136 Mac OS CUBRID 매니저 Remote host closed connection during handshake 오류 1 오충 2020.05.04 53
3135 Failback 하는 방법 좀 알려 주세요. 1 Philip Park 2020.04.28 47
3134 Cubrid ha master slave 확인 어떻게 하나요? 5 file Philip Park 2020.04.27 61
3133 큐브리드 with rollup 결과row에 null이 나오는데 이 null을 변경할수 있을까요? 1 file dkkdkdkdkdk 2020.04.24 34
3132 큐브리드 날자 변환 저장 방법문의 2 파랑조아유 2020.04.24 47
3131 csql 출력 결과 string '' 제거 및 구분자 표시 방법 4 nagh 2020.04.23 67
3130 csql interpreter에서 \(역슬래쉬) 사용 문제 2 nagh 2020.04.21 34
3129 SELECT 전체 갯수에 대해 질문 드리겠습니다. 1 훈입니다. 2020.04.17 48
3128 프로시저 클래스 등록 관련입니다. 1 mon 2020.04.16 36
3127 INSERT 한글 깨짐 관련 질문 드립니다. 1 마이클 2020.04.16 52
3126 리눅스 파이썬에서 큐브리드 연동 배수민 2020.04.14 74
3125 릴리즈된 10.1.0.0004 ADO.NET 드라이버를 다운받을수 없습니다. 2 file Js 2020.04.14 30
3124 쿼리문으로 컬럼의 데이터 타입을 구할 수 있나요? 3 mon 2020.04.13 42
3123 케릭터셋 문제입니다. 1 훈입니다. 2020.04.13 51
3122 마지막 공백 인식 문제입니다. 2 mon 2020.04.10 54
3121 파일에서 읽어 저장 2 현수 2020.04.09 45
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 163 Next
/ 163

Contact Cubrid

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