FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

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


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

안녕하세요 java stored procedure를 통해 사용자함수를 생성하여 사용하고 있습니다.


stored procedure가 수행되면서 6천건 수행시 약 4.5초에 시간이 소요됩니다. (Select / Update )


해당 작업이 수행시에는 다른 세션에서 dml 수행시 


실행 오류 : -74

Your transaction (index 1, DBA@msdn-special|2624) timed out waiting on   IS_LOCK lock on class th_pzdcr_loginfo. You are waiting for user(s) DBA@msdn-special|cub_cas(8344) to finish.[CAS INFO-192.168.0.108:30000,1,2624],[SESSION-32],[URL-jdbc:cubrid:192.168.0.108:30000:sanghun_potal:dba:********:].


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


stored procedure랑은 관계없이 해당 테이블에 DML작업 수행시 (SELECT 포함) LOCK을 걸게 되는것으로 보입니다.


4.5초 Select query 를 양쪽 세션에서 동시에 수행할 경우 먼저 실행한 쿼리만 수행되고 


수행중에 들어온 쿼리는 위와같은 에러를 동일하게 뱉어냅니다.


Select Query도 LOCK을 걸게되는것 같은데 Select 시에는 Lock에 구애없이 수행 가능한 방법이 없나요??




  • ?
    정만영 2014.12.11 20:22

    안녕하세요.


    CUBRID LOCK 관련 파라미터 $CUBRID/conf/cubrid.conf 파일에 lock_timeout 설정해 주시면 됩니다.


    이 파리미터는 잠금 대기 시간을 지정하기 위한 클라이언트 파라미터로 지정된 시간 이내에 잠금이 허용되지 않으면 해당 트랜잭션이 취소되고 오류가 반환되고 기본값인 -1로 설정하면 잠금이 허용될 때까지의 무제한 대기하며,  0으로 설정하면 잠금을 대기하지 않습니다.


    참조: CUBRID R9.x 이하 버전은 lock_timeout_in_secs 파라미터명을 사용

  • ?
    cgkang 2014.12.11 21:28

    오류 메시지는 IS_LOCK을 대기하다 타임아웃이 발생한 것입니다.

    IS_LOCK은 select 쿼리가 수행될 때 테이블에 걸게 되는데,

    다른 테이블이 X락을 잡고 있으면 IS_LOCK을 획득하지 못하게 됩니다.

    테이블에 X락이 걸리는 경우는 테이블 스키마를 변경하거나, 테이블 전체를 변경하는 작업이 발생하는 경우입니다.

    sp안에서 update하는 쿼리가 테이블 전체를 대상으로 변경하거나,

    where절의 조건이 인덱스를 활용하지 못할 경우 테이블에 X락을 잡고 수행하게 되어 다른 질의는 수행하지 못하게 됩니다.

    where 절에 인덱스를 사용할 수있는 조건이 추가되면 레코드별로 락을 잡게 되어서 다른 SELECT가 대기하는 상태는 없어질 수 있는데, 이런 경우 레코드에 잡히는 락 개수가 많아지거나, 동시에 수행할때 데드락 발생 가능성이 높아질 수 있으니 주의해야 합니다.

    단순한 SELECT쿼리가 두 개 수행될 때 IS_LOCK대기하는 경우는 없으니 참고하기 바랍니다.



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 10 admin 2024.04.23 37821
2027 데이터베이스 볼륨정보의 일반볼륨항목에 Free 가 0인경우... 1 사운드해븐 2014.12.29 6337
2026 CUBRID 매니저 에서 데이터베이스 접속시 시간 지연과 오류 1 secret ni Chang 2014.12.29 10
2025 CUBRID/bin 폴더에 생성 되는 dmp 파일 관련하여 문의드립니다. 3 secret 질의응답요청 2014.12.26 14
2024 createStatement 관련 1 김대현 2014.12.26 5993
2023 접속 자동으로 끊김 6 secret moon 2014.12.24 20
2022 HA 구성시 동기화 2 알칸펠 2014.12.24 5703
2021 테이블 명이 동일한 상태에서 효율적인 처리 방법 문의 1 최명호 2014.12.23 5224
2020 2008 R4 리눅스에서 완전 삭제 방법 3 알칸펠 2014.12.22 5797
2019 ODBC 를 통할 경우 텍스트 잘림 2 file OO준 2014.12.22 7249
2018 CUBRID/bin 폴더에 생성 되는 dmp 파일 관련하여 문의드립니다. 3 질의응답요청 2014.12.19 6575
2017 서비스 트레이 작동 중지 문제 1 file 조금느린아이 2014.12.16 7381
2016 ubuntu 큐브리드 설치시 서비스 오류 1 file Hunyho 2014.12.16 5371
2015 jsp 커넥션 문의합니다. 1 secret 사용자3 2014.12.15 7
2014 데이터베이스 백업된 파일로 복구하기 1 오명일 2014.12.15 5535
2013 테이블 복구 문의합니다. 1 찌후맘 2014.12.11 7274
» 쿼리수행시 Lock 관련 문의 2 nagh 2014.12.11 11601
2011 설치후 오류 메시지 3 moon 2014.12.10 5481
2010 여러개 데이터 한번에 insert 문 수행하는 방법 1 whwpdn 2014.12.10 12837
2009 하나의 노드에 여러개의 db가 있을때, ha 구성을 안한 db는 사용하지 못하는 문제. 1 깜장매2 2014.12.09 6055
2008 PreparedStatement 변수 바인딩 1 접때그넘 2014.12.06 8125
Board Pagination Prev 1 ... 104 105 106 107 108 109 110 111 112 113 ... 210 Next
/ 210

Contact Cubrid

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

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

나눔고딕 사이트로 가기

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5