Background Image

FORUM

?

단축키

Prev이전 문서

Next다음 문서

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


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

OS
Redhat 7.6 Enterprise
CUBRID Ver.
10.1.5.7809
CUBRID TOOL Ver.
10.2.0.0001
응용 환경(API)
JAVA


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

 

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


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

안녕하세요.

큐브리드 HA 구성중인 서버 하나에서 큐브리드를 재설치 한 후, INSERT된 데이터에 오류가 있어서 문의드립니다.

 

큐브리드를 사용중이던 서버에서, 큐브리드 설치 쉘스크립트를 재설치하였습니다.

설치 후, 서비스 동작시키는데 별다른 오류는 없었습니다.

 

기존과 동일한 이름의 데이터베이스를 만들고

큐브리드 매니저를 통해 "내보내기"를 해논 ddl 5종(index, schema, serial, trigger, view)과 데이터를 재설치 후, "가져오기"를 통해서 다시 데이터베이스에 넣었습니다.

 

이후 서비스를 띄우고 운영중에 있습니다.
( 재설치된 서버 : Master  /  다른 HA구성 서버 : Slave )

 

운영중 데이터를 분석하다보니 오류가 있습니다.

"가져오기"를 통해 들어온 데이터들과 운영중에 insert 된 데이터들에 문제가 있었습니다.

예를들어, 아래와 같은 테이블이 있다고 가정했을때

TEST_TABLE

컬럼 : use_yn / CHAR(1) / 기본값 'N'

        use_number / INTEGER

        create_date / DATE / 기본값 SYS_DATE

 

INSERT TEST_TABLE (use_yn, use_number) VALUES ('Y', 8412) 를 실행시켰을 경우,

use_yn => 1   use_number => 2459710   create_date => 4689-07-07  이런식으로 데이터가 들어가고 있습니다.

 

모든 INSERT 된 데이터들이 문제가 있는것은 아니고 정상적인 데이터도 있습니다.

대략적으로 [운영중 insert 데이터] 90% -> 비정상, 10% -> 정상 

               [가져오기 insert 데이터] 10% -> 비정상, 90% -> 정상

 

큐브리드매니저, csql 모두 동일하게 조회되고 있습니다.

 

해당 오류 점검중 확인한 내용은, 구축당시부터 동일한 이슈가 있었다는것입니다.

1만건의 데이터중 100건 정도가 위와 같이 데이터가 잘못들어간 오류들이 있었던 것을 확인했습니다.

(Y -> 1로, N -> 0으로, 날짜, Integer가 잘못들어가는 이슈)

 

재구축 후 운영중 들어간 데이터들을 확인해보니, HA 구성된 다른 서버에는 정상적으로 데이터가 들어가 있습니다.

use_yn => Y   use_number => 8412   create_date => 2022-05-12

 

"내보내기"를 하였던 sql문들을 열어서 확인했을때는 create문, insert문은 정상적으로 작성되어 있었습니다.

 

기존에 운영중인 서비스라 쿼리에 문제가 있는것은 아니며, 동일한 트랜잭션으로 INSERT 되었을 다른 HA 서버에는 정상적으로 들어가있습니다.

CSQL을 이용하여 DESC TEST_TABLE을 해보아도 동일하게 출력되고 있습니다.

큐브리드 설치중에 문제가 있었다면, 설치가 안되거나 오류 메세지가 나왔을텐데 따로 확인된 오류는 없었습니다.

 

어떤점이 문제고, 어떻게 해결해야하는지 문의드립니다.

 

감사합니다.

 

 

  • ?
    오명환 2022.05.12 13:21
    HA의 slave 또는 replica를 구성(또는 재구성)하실때 반드시 master의 백업본을 가지고 구성하셔야 합니다.
    unloaddb 또는 query browser의 export 기능을 통해 가져온 schema를 이용할 경우 master의 테이블 컬럼 저장 순서와 새롭게 구축하는 slave(또는 replica)의 테이블 컬럼 저장 순서가 다를 수 있습니다.
    복제하는 방식이 테이블의 컬럼 저장 순서가 동일하다는 가정에서 복제 로그를 읽어서 slave(또는 replica)에 insert 구문이 아닌 이미지 복제 수준으로 반영하게 되어 있어, 테이블의 컬럼 저장 순서가 다른 경우 말씀하신대로 복제된 데이터가 틀려집니다.

    구성 방법에 대해서는 매뉴얼을 첨조하세요.
    https://www.cubrid.org/manual/ko/10.1/ha.html#building-replication
  • ?
    큐브짱 2022.05.13 11:10
    안녕하세요.
    복제한 수많은 테이블들중, 하나의 테이블에서만 해당 이슈가 발생한다는게 특이하긴하지만... 말씀주신 내용으로 다시 해보겠습니다.

    그러면 재구축 이후에 운영하면서 쌓인 데이터들에 동일한 이슈가 발생하는 원인은 무엇인가요?
  • ?
    오명환 2022.05.13 11:38
    말씀드린대로 master와 slave가 컬럼 저장 순서가 다른 상태에서 지속적인 fail-over가 발생한 후 복제 발생한다면 계속 틀어질 수 있습니다.

    CM은 항상 master를 바라보고 되어 있는데, fail-over가 발생하면 예전의 slave를 바라보게 되고, csql는 특정 서버를 지정하지 않으면 현재 실행한 곳의 서버로 연결됩니다.
    fail-over에서 의해 다양한 케이스가 발생할 수 있으므로, 사용자님이 경험하신 상황이 발생할 수 있습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3774 attribute가 AUTO_INCREMENT로 생성됐는지 확인할 수 있는 딕셔너리는 무엇인가요? 3 새옹지마 2023.01.08 365
3773 varchar <-> collection으로 변환이 가능한가요? 1 새옹지마 2023.01.08 48
3772 SET, MULTISET, LIST과 같은 컬렉션 타입 컬럼에 저장된 원소의 갯수를 알고 싶습니다. 1 새옹지마 2023.01.06 131
3771 JDBC로 SET 타입의 데이터를 get/set 하는 메소드는 각각 무엇인가요? 4 새옹지마 2023.01.04 97
3770 JDBC로 BIT(n) 타입의 데이터를 get/set 하는 메소드는 각각 무엇인가요? 2 새옹지마 2023.01.03 56
3769 큐브리드 매니저 관리모드 접속 시 오류가 발생합니다. 4 file 정A 2023.01.03 271
3768 WHERE절에 REGEXP_REPLACE를 넣고 실행하면 다운됩니다. 3 거지같은 2023.01.02 318
3767 암호화관련 문의 드립니다. 1 file 초코초코초 2022.12.29 102
3766 모든 테이블의 목록과 각 테이블의 로우 (레코드) 수 확인 4 키롱 2022.12.28 198
3765 큐브리드 FOR문 관련 질의드립니다. 1 계란 2022.12.28 220
3764 [처리완료] 큐브리드 unloaddb, loaddb 시 특수문자 깨짐 및 Lexical error 4 file 백수인 2022.12.27 137
3763 쿼리 튜닝 및 실행계획 관련 문의 드립니다. 3 file kikiki767 2022.12.23 137
3762 펑션 오류 문의드립니다 8 초코초코초 2022.12.17 141
3761 insert 시 오류 문의 1 steve 2022.12.16 127
3760 cubrid11.2 embedded SQL 지원 여부 및 메뉴얼 위치? 1 jjune1206 2022.12.15 45
3759 Error : [-596] The 1953 pages of total temporary space allowed have been exceeded. 2 리들러 2022.12.10 267
3758 큐브리드 DB링크 문의드립니다. 4 file 초코초코초 2022.12.01 150
3757 Oracle to CUBRID Migration 방안 1 DBS 2022.12.01 96
3756 cubrid 엔진 설치 오류 1 file minsung 2022.12.01 72
3755 kill 명령어로 프로세스가 죽지 않을때 3 나라디 2022.12.01 156
Board Pagination Prev 1 ... 7 8 9 10 11 12 13 14 15 16 ... 200 Next
/ 200

Contact Cubrid

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