Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Linux 64bit
CUBRID Ver.
8.4.1.30011
CUBRID TOOL Ver.
10.1.0.0006 
응용 환경(API)
java, kotlin

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


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


안녕하세요

분산데이터베이스 환경때문에 CUBRIDXADataSource 를 사용해서 구성했는데요

rollback 되지 않아서 문의 드립니다


AtomikosDataSourceBean를 이용하였고 jtaTransactionManager 를 적용하였습니다


로그상에는 CUBRIDXAResource.rollback 이 호출된걸로 찍히는데 디비 조회해보면 데이터가 존재합니다

분산데이터소스쓰지 않고 일반형태로 구현하면 롤백이 정상적으로 동작합니다


빠진 설정이 있는지 도움주실수 있을까요?


테스트코드를 첨부합니다. DemoApplicationTests.java testcase를 실행하면 됩니다 

http://naver.me/xScpRH4M (게시판 첩부가 되지 않아 다운로드 링크 추가했습니다)


  • ?
    주영진 2021.02.16 18:36

    안녕하세요.
    큐브리드 이용에 감사드립니다.

     

    테스트 코드를 다운로드 받아서 실행해봤습니다.
    말씀해주신 것과 동일하게 INSERT문을 ROLLBACK 하지 않고, COMMIT 했습니다.

     

    SQL 로그를 보니 AUTOCOMMIT으로 처리하고 있습니다.

    트랜잭션 처리를 위해서는 AUTOCOMMIT을 FALSE로 설정하고 DB 연결을 해야 합니다.

     

    21-02-16 15:27:24.364 (0) STATE idle
    21-02-16 15:27:24.818 (0) CLIENT IP 192.168.137.1
    21-02-16 15:27:24.818 (0) CLIENT VERSION 10.1.3.7765
    21-02-16 15:27:24.818 (0) session id for connection 0
    21-02-16 15:27:24.820 (0) connect db demodb@localhost user dba url xa session id 5
    21-02-16 15:27:24.820 (0) DEFAULT isolation_level 4, lock_timeout -1
    21-02-16 15:27:24.821 (1) prepare 0 INSERT INTO test_table(id, name, vv, pp) VALUES (33, '33', '33', '33')
    21-02-16 15:27:24.822 (1) prepare srv_h_id 1
    21-02-16 15:27:24.845 (1) set query timeout to 0 (no limit)
    21-02-16 15:27:24.845 (1) execute_all srv_h_id 1 INSERT INTO test_table(id, name, vv, pp) VALUES (33, '33', '33', '33')
    21-02-16 15:27:24.853 (1) execute_all 0 tuple 1 time 0.007
    21-02-16 15:27:24.853 (0) auto_commit (local)
    21-02-16 15:27:24.853 (0) auto_commit 0
    21-02-16 15:27:24.853 (0) *** elapsed time 0.032

     

    AUTOCOMMIT을 FALSE로 설정하고 DB 연결을 하면

    SQL 로그에 auto_commit이 아닌 end_tran COMMIT 또는 end_tran ROLLBACK 이 출력되어야 합니다.

     

    XA SESSION에서는 AUTOCOMMIT이 FALSE로 되어야 하는데 이 부분에 문제가 있는 것같습니다.

    명시적으로 SESSION의 AUTOCOMMIT을 FALSE로 설정하는 방법이 있다면 설정 후 테스트를 부탁드립니다.

     

    JDBC Driver에 대한 부분은 내부에서 검토해보겠습니다.

     

    참고로 CUBRID 에서 SQL 로그 기본 위치는 $CUBRID/log/broker/sql_log/<broker_name>_<app_server_num>.sql.log 입니다.

    추가로 테스트하실 때 참고하시면 도움이 될 것 같습니다.

  • ?
    잠깐하는 2021.02.19 10:09
    답변감사드립니다!
    autocommit 정보를 바꿀곳을 찾지못해서
    CUBRIDXADataSource 를 상속받아 getXAConnection 시 autocommit 정보를 false로 바꾸도록 코드를 수정하고 테스트하니 롤백이 정상적으로 동작합니다
    디버깅을 해보니 tran_start 시 autocommit을 false로 바꾸긴 하는데 커넥션 생성시 기본값 true 상태에서 커낵션에서 뭔가 동작이 이뤄지는듯합니다

    임시로 위와같이 하여도 문제가 없을까요

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 123
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4476
3702 큐브리드매니저에서 한글은 어떻게? 1 초짜큐브 2010.07.12 10050
3701 큐브리드매니저에서 질의결과가 나타나지 않습니다. 3 file 미스터투 2011.06.19 9112
3700 큐브리드매니저에서 데이터 내려받기시 컬럼명 같이 저장기능 추가 2 file 고영진 2009.09.24 12894
3699 큐브리드매니저에서 값을 바로 수정하기는 어려운가요? 2 file 고영진 2009.09.24 13815
3698 큐브리드매니저에서 dba암호를 걸어버리면 연결할수 없다.브로커와 구동상태를 점검하라. 이렇게 오류가 나오네요 2 블루토토 2011.06.23 10035
3697 큐브리드매니저에서 NULL값과 문자속성의 빈값을 구분하여 표시 필요 2 file 고영진 2009.09.23 14594
3696 큐브리드매니저.. sql파일 열기가 안되는거 맞나요? 6 안지민 2012.08.20 8016
3695 큐브리드매니저 패스워드 변경 문의건 1 file yurrrr 2023.10.16 102
3694 큐브리드매니저 접속 문제 5 ykh 2011.03.09 11816
3693 큐브리드매니저 2008 R2.0 데이터 올리기 기능 사용시 발생한 오류 12 file 고영진 2009.09.06 15601
3692 큐브리드를 지원하는 모델링 툴이 있나요?? 1 십칠미리 2009.12.10 10071
3691 큐브리드를 시작할수없습니다. 2 SoMa 2011.09.04 9384
3690 큐브리드를 설치하고 실행하려는데 아래와 같은 오류가 납니다. 1 VL-2536 2009.08.14 9020
3689 큐브리드를 사용해 윈도환경에서 사용할 프로그램을 개발코자 합니다 1 혜승아빠 2010.01.08 9763
3688 큐브리드를 HA 구성 문의드립니다..여러개가 가능할까요? 1 라면 2016.10.21 13981
3687 큐브리드로 작업을 하고 있었는데요 3 별이랑 2016.07.22 11491
3686 큐브리드로 두 날짜간의 년도 차이를 구하고 싶습니다. 1 aaa 2021.01.04 644
3685 큐브리드데이터베이스검사시 나오는 불량. 4 file 늑대의호기심 2016.11.22 12885
3684 큐브리드는 안드로이드 연동이 안되나요? 4 file 달선생 2012.05.01 22400
3683 큐브리드는 mysql 의 varchar(255) 와 동일한 길이가 아니네요? 3 초보 2009.12.28 22102
Board Pagination Prev 1 ... 11 12 13 14 15 16 17 18 19 20 ... 201 Next
/ 201

Contact Cubrid

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