Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window Server 2008 R2 Enterprise, 64bit (Service Pack 1)
CUBRID Ver.
CUBRID 9.3 <9.3.9.0002> <64bit release build for Windows_NT> <Aug 4 2007 12:26:47>
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java

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


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
에러 재현 방법 및 정보는 아래와 같습니다.


## session 1 정보 ##

- 환경 : transaction isolation level 1

- 쿼리 수행 : 

 - 동일 테이블에 update

 - 동일 테이블에 insert

 - 동일 테이블에 delete


## session 2 정보 ##

- 환경 : transaction isolation level 1

- 쿼리 수행 : 

 - 동일 테이블에 update

 - 동일 테이블에 insert

 - 동일 테이블에 delete


## 조금 더 상세히는 아래와 같습니다.

session 1 : update 

session 1 : insert

session 1 : delete


session 2 : update

session 2 : insert

session 2 : delete


session 2 : commit

session 1 : commit


위와 같은 상황(?)에서 -72에러가 납니다.

autocommit false인 상태이며, session별로 다른 PK를 갖은 row를 대상으로 update/insert/delete 합니다.


## 에러 정보 (C:\CUBRID\log\server\ Table_date.err 파일) ##


ERROR *** file ..\..\src\transaction\lock_manager.c, line 2659 ERROR CODE = -72 Tran = 8, CLIENT = SVDB-CUBRID:cub_cas(10744), EID = 4

Your transaction (index 8, DBA@SVDB-CUBRID|10744) has been unilaterally aborted by the system.


72번에러가 납니다. 이전 Q&A건들을 보니, deadlock이라는 것을 확인하였습니다.

기본 설정으로 사용중이었는데 level 1로 낮추면 해결될 수 있을 것이라 생각했으나, 동일하게 발생합니다.


command 창(cmd > csql)로 하였을 때는 transaction level 1일 때 재현이 되지 않습니다.

그러나, 코드상으로 돌릴 시 재현되므로, 확인이 필요합니다.


위 session 1/2는 동일 action이나, update/insert/delete 되는 대상이 겹치지 않습니다.


## 테이블 정보 ##

CREATE TABLE table1(

C_CODE varchar(32) NOT NULL,

TO_DEPTCODE varchar(32) NOT NULL,

TO_ROLECODE varchar(32) NOT NULL,

TO_POSITIONCODE varchar(32) NOT NULL,

E_DEPT varchar(16) NOT NULL,

TO_DESC varchar(256),

TO_DATE bigint,

TO_ADMINID varchar(64),

CP_HASHCODE varchar(32) NOT NULL,

TO_ADMINNAME varchar(128),

R_CONTEXT int NOT NULL,

N_CONTEXT int NOT NULL,

L_CODE varchar(32) NOT NULL,

C_METHOD varchar(32) NULL,

C_START_DATE bigint,

C_END_DATE bigint,

F_STATUS varchar(32) NOT NULL,

PRIMARY KEY CLUSTERED (C_CODE,TO_DEPTCODE,TO_ROLECODE,TO_POSITIONCODE,E_DEPT,R_CONTEXT,N_CONTEXT,F_STATUS)

);

  • ?
    오명환 2018.09.05 17:14
    9.X 이하 version은 동시성 보장을 위해 2PL 매커니즘을 사용하고 있습니다. 10.X이상부터는 MVCC 매커니즘을 사용합니다.
    문의하셨던 문제는 transaction내에서 insert, delete, update하면서 record lock이 아닌 index lock에 의해 발생하는 것입니다.
    csql에서 발생하지 않은 것은 isolation 변경이 아닌 csql의 default option이 auto commit으로 되어 있어, auto commit에 의해 시나리오 수행된 것입니다.

    이 문제는 commit 단위를 좀 더 줄이시거나, MVCC 매커니즘을 구현된 10.1를 사용하시면 됩니다.
    9.X와 10.X는 볼륨이 호환되지 않으므로, cubrid unloaddb 한후 cubrid loaddb로 데이타를 이관하시면 됩니다.
  • ?
    술먹지마라 2018.09.06 09:51
    안녕하세요.
    답변 감사합니다.

    추가적으로 질문이 있습니다.

    recored lock 이 아닌 index lock 이라 하셨는데,
    현재 재현되는 부분은 서로 다른 index를 가진 rows 입니다.
    이 부분도 2PL, 동시성 보장과 관련이 있는 것인지 궁금합니다.

    확인 부탁 드립니다.
    (10.1버전 (x64) 를 설치하고 하였을때 위에 언급하신 것과 같이 오류는 재현되지 않습니다.
    큐브리드 사이트 내에서 받을려고하면, x64도 x86으로 받아지는데... F12로 변경해서 받아야 합니다.. 나중에 수정 부탁 드려요!)

  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views136
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4477
    read more
  3. jdbc 버전 확인 방법

    Date2018.10.08 Byabg Views1585
    Read More
  4. ADO.NET dll 참조

    Date2018.10.04 Byabc12 Views895
    Read More
  5. CUBRID 가용메모리 등 에러발생..

    Date2018.10.03 By고치고싶어요 Views603
    Read More
  6. cubrid manager 데이터베이스 항목.

    Date2018.10.02 Byneo Views194
    Read More
  7. 간단한..질문좀..

    Date2018.10.01 By마리오네트 Views194
    Read More
  8. jdbc 드라이버 버전

    Date2018.10.01 Byabc12 Views1625
    Read More
  9. 트리거 사용시 임시변수

    Date2018.10.01 By지구인다 Views253
    Read More
  10. 오라클 트리거를 옮겨오고싶습니다.

    Date2018.09.28 By지구인다 Views310
    Read More
  11. cubrid linux 설치시 cli 인터렉티브 없이 설치할 수 있는방법좀 부탁드립니다.

    Date2018.09.28 Bykaroscha Views224
    Read More
  12. 초를 시분초로 바꾸는 방법 문의 드립니다.

    Date2018.09.18 Byqwerty Views1061
    Read More
  13. 큐브리드 ODBC설정방법문의

    Date2018.09.18 By개발자1111 Views664
    Read More
  14. 큐브리드 매니저 실행시 오류

    Date2018.09.18 By개발자1111 Views275
    Read More
  15. 데이터베이스 공간 정리(compactdb) 실행중 정지가능한가요?

    Date2018.09.11 By배추 Views351
    Read More
  16. Cubrid 9.3 > 10.1 업그레이드 문의

    Date2018.09.11 By술먹지마라 Views348
    Read More
  17. db link는 지원 계획이 있나요?

    Date2018.09.07 Byqwerty Views592
    Read More
  18. [Cubrid 9.3] POSIX ERROR 문의

    Date2018.09.06 Byvasconcelos Views360
    Read More
  19. 문의드립니다.

    Date2018.09.03 By팩트드림 Views482
    Read More
  20. Cubrid 9.3 isolation 이슈 문의

    Date2018.08.30 By술먹지마라 Views398
    Read More
  21. CUBRID TDE 관련 질문

    Date2018.08.30 By디비디비딥 Views352
    Read More
  22. Cubrid Linux용 ODBC가 없나요?

    Date2018.08.28 Byserapian Views469
    Read More
Board Pagination Prev 1 ... 52 53 54 55 56 57 58 59 60 61 ... 201 Next
/ 201

Contact Cubrid

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