메뉴 건너뛰기

조회 수 1973 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

MySQL 서버를 마스터/마스터로 DB replication 할 경우, MySQL 테이블에 AUTO_INCREMENT key 를 포함되어 있으면 마스터#1 및 마스터#2 DB 에 모두 INSERT 할 경우 중복키로 충돌이 발생하여서 replication 을 위한 Slave SQL 쓰레드가 중단될 수 있습니다. replication 에서 AUTO_INCREMENT 로 인한 중복키 충돌을 예방하는 방법은 다음과 같습니다.

1. 마스터​ #1 에서 아래와 같이 실행한다.

  - 아래와 같이 실행하면 1, 3, 5 ... 와 같이 홀수로 key 가 생성된다.​


​  mysql> set global auto_increment_increment=2;

  mysql> show variables like 'auto_increment%';
+---------------------------------+-------+
| Variable_name                  | Value |
+---------------------------------+-------+
| auto_increment_increment  | 2     |
| auto_increment_offset        | 1     |
+---------------------------------+-------+


2. 마스터​ #2 에서 아래와 같이 실행한다.

  - 아래와 같이 실행하면 2, 4, 6 ... 와 같이 짝수로 key 가 생성된다.​


​  mysql> set global auto_increment_increment=2;

  mysql> set global auto_increment_offset=2;

  mysql> show variables like 'auto_increment%';
+---------------------------------+-------+
| Variable_name                  | Value |
+---------------------------------+-------+
| auto_increment_increment  | 2     |
| auto_increment_offset        | 2     |
+---------------------------------+-------+

3. 주의사항

  - 위와 같이 설정하면 홀수, 짝수 값이 순차적으로 증가하지 못하고 중간에 누락된 것처럼 보여질 수 있다.

  - 만약 AUTO_INCREMENT 값이 1부터 순차적으로 증가하되 누락된 수가 없어야 한다면 위와 같이 설정하면 안 된다.

  - INSERT 쿼리가 마스터#1 및 마스터#2 에서 임의의 순서대로 자주 실행된다면 AUTO_INCREMENT 잠금으로 인해 대기 현상이 발생할 수 있다.


List of Articles
번호 제목 날짜 조회 수
46 order by field 와 union, 원하는 대로 정렬 하기 2021.03.26 776
45 SQL 고급 file 2017.12.22 6042
44 Union 사용법. 여러 테이블의 같은 값을 한번 쿼리로 추출하기 2017.11.21 3921
43 UPDATE ~ CASE 문을 사용한 조건별 업데이트 file 2020.07.28 1400
42 [mysql,mariaDB] 컬럼 암호화, 복호화 2020.11.25 780
41 [MySQL] 백업 및 복구 2017.04.12 5392
40 [MySQL] 세로열을 가로열로 출력하기 2019.03.05 2098
39 각각의 게시판에서 제일 최근글하나씩을 모아 정렬 2016.08.30 5812
38 날짜 관련 함수 모음. 2017.12.22 3976
37 날짜와 시간 데이터 2016.12.23 5996
36 날짜형(DATETIME) 빼기 2021.03.26 148
35 다른 테이블 데이터를 원하는 테이블에 업데이트 시키기 2017.11.16 5076
34 다양한 단위의 시간차 구하기 2015.12.19 8360
33 덤프할때 한글깨짐 해결 2016.12.23 5636
32 데이타베이스 또는 테이블 정보 2016.12.23 5534
31 데이터베이스 파티셔닝이란 2017.12.28 4262
30 데이터베이스별 / 테이블별 용량 확인 하기 2023.01.10 118
29 두 테이블을 비교하여 한쪽테이블에는 있지만 다른 테이블에는 없는 값을 뽑아내보자! 2017.11.21 5390
28 문자형 데이터 2016.12.23 5646
27 백업시 캐릭터셋(charset) 지정하기 2017.04.12 5071
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved