Background Image

FORUM

조회 수 221 추천 수 0 댓글 7
?

단축키

Prev이전 문서

Next다음 문서

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


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

OS

Linux 2.6.32-696.23.1.el6.x86_64

CUBRID Ver.

11

CUBRID TOOL Ver.

[도움말]-[버전정보] 확인

응용 환경(API)

java, php, odbc 등 입력


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


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


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
큐브리드 db를 사용중인데, 서비스 지연이 발생하였습니다.

대부분의 지연 thread들의 stack trace를 확인해보니 다음과 같았습니다.

cubrid.jdbc.jci.UTimedDataInputStream.read() 호출 -> java.io.DataInputStream.read() -> java.net.SocketInputStream.socketRead() 단계에서 대기 상태였습니다.

UtimedDataInputStream클래스의 read() 메소드가 호출되기전, commit()이 호출되고 endTreansaction() 메소드가 호출된것으로 보아 request가 query수행 후, 사용 connection을 반환하고 종료되고 있는 과정으로 추정할 수 있었습니다. 

질문은, endTransaction이 호출되고 다음으로 호출되는 UtimedDataInputStream.read() 는 무엇을 의미하는지 궁금합니다. 

  • ?
    airnet 2022.02.08 17:37
    안녕하세요
    큐브리드 이용해 주셔서 감사합니다.

    위의 내용 만으로는 어떤 상황에서 서비스 지연이 발생되는 확인은 어려워 보입니다.
    그리고, 질문하신 endTransaction()에서 END_TRANSACTION 을 전송 했다면 UtimedDataInputStream.read() 는 END_TRANSACTION 의 에러 코드를 읽어 오는 동작 입니다.
    참고로, END_TRANSACTION은 현재 진행 중인 트랜잭션에 대해서 커밋(commit)이나 롤백(rollback)을 수행하며, 결과로 에러 코드 를 반환 받습니다.
  • ?
    엔디미온 2022.02.08 17:56
    commit()이 호출되었습니다.
    UtimedDataInputStream.read() 호출 후, aries.base.vm.SocketInputStream.read() 이 호출되었는데요. aries.base.vm 클래스가 호출되는 것도 큐브리드 드라이버 레벨에서 접근한건가요?
  • ?
    오명환 2022.02.08 20:42
    commit() 호출시 지연 현상 발생하는 것으로 보이는데, 알려주신 정보로는 어떤 부분이 정확히 문제인지 파악하기 힘드네요.
    $CUBRID/log/broker/sql_log./ 로 가시면 수행했던 질의 및 commit의 수행 시간를 확인할 수 있습니다.
    이 로그를 가지고 해당 시간에 수행했던 commit의 수행 시간을 확인 후 문제점을 찾아나가는 것이 좋을 것 같습니다.

    JDBC URL에서 30000 포트를 사용하셨으면 query_editor_ 시작하는 sql.log를 참조하시고, 31000 포트를 사용하셨으면 broker1_ 시작하는 sql.log를 참조하시면 됩니다.

    자세한 내용은 https://www.cubrid.org/manual/ko/11.0/admin/troubleshoot.html# 매뉴얼을 참조하세요.
  • ?
    엔디미온 2022.02.09 09:13
    aries.base 패키지에 대한 질문에 답변 부탁드립니다.
  • ?
    엔디미온 2022.02.09 09:16
    UtimedDataInputStream이 호출되고 socketRead() 상태였는데, 디비로부터 commit()에 대한 결과를 받고 있던지 또는 받기 위해서 대기중이었다로 보는게 맞겠죠? 그리고 위에서 언급해주신 로그들을 통해서 오래걸린 이유는 로그를 보면 되구요.
  • ?
    오명환 2022.02.10 08:13
    네, SQL log에 commit이 지연이 있었는지 우선 확인해보세요.
    그리고, aires.base.vm은 cubrid JDBC에서 직접 호출하는 package는 아닙니다.
  • ?
    엔디미온 2022.02.10 09:36
    네 답변 감사드립니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4443
» cubrid JDBC Driver의 클래스 내용이 궁금합니다. 7 엔디미온 2022.02.08 221
426 AUTO INCREASE 가 편집이 안됨 2 file 큐브리드어려워요 2022.02.08 268
425 CAN NOT COMMUNICATE WITH BROKER / 1 폭스공이삼 2022.02.10 590
424 csql로 .sql가져오기 시, 한글 깨짐 발생 2 도우너19 2022.02.11 391
423 생성된 db에 사용자와 스키마 추가하는 법(큐브리드매니저, csql 인터프리터 사용x) 9 도우너19 2022.02.15 428
422 Cubrid Manager Hang 2 file user 2022.02.15 84
421 php-cubrid 연동 시 cubrid driver 인식 문의 2 file devlsy 2022.02.15 118
420 권한 부여 방법 2 bm 2022.02.15 223
419 nodejs 사용하여 insert 작업 후에 생성된 ID값을 얻고 싶은데 방법이 있을까요? 3 jslee 2022.02.16 398
418 데이터 내보내기 기능 오류 1 큐린이 2022.02.16 170
417 select sql실행시 에러 3 file rhrnak 2022.02.18 823
416 스크립트와 cubrid manager 어떤게 문제 일까요? 1 윈디 2022.02.18 85
415 Cannot allocate query entry any more. Maximum allocatable entries are 100. 4 jslee 2022.02.21 119
414 큐브리드 서로 다른버전 원격접속 불가능 한게 맞나요?? 4 김성민 2022.02.21 130
413 on duplicate key update values 사용 방법 질문 2 jslee 2022.02.22 85
412 정수/정수 결과를 소수로 출력하게 하는법 1 file suyeon 2022.02.23 193
411 db 로그인시 log fatal error 오류 문의 드립니다. 2 jjbk 2022.02.28 190
410 Oracle에서 Cubrid 로 이관을 하려고 하는데 CMT말고 할수 있는 방법이 있을까요? 1 curo 2022.03.02 81
409 큐브리드 마이그레이션중 에러 7 밍아 2022.03.03 257
408 nodejs 많은 데이터 관련해서 트랜잭션 작업시 에러 발생 15 jslee 2022.03.11 909
Board Pagination Prev 1 ... 174 175 176 177 178 179 180 181 182 183 ... 200 Next
/ 200

Contact Cubrid

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