>  기사  >  데이터 베이스  >  MySQL에서 데이터 복제 및 동기화를 달성하는 방법은 무엇입니까?

MySQL에서 데이터 복제 및 동기화를 달성하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-07-29 08:24:402607검색

MySQL은 현재 가장 널리 사용되는 관계형 데이터베이스 관리 시스템 중 하나입니다. 고가용성과 데이터 보호를 달성하기 위해 데이터 복제 및 동기화를 지원합니다. 이 기사에서는 MySQL에서 데이터 복제 및 동기화를 구현하는 방법을 소개하고 몇 가지 코드 예제를 제공합니다.

1. MySQL 데이터 복제의 기본 원칙
MySQL 데이터 복제는 한 데이터베이스에서 다른 데이터베이스로 데이터를 복사하여 수행됩니다. 이는 하나의 데이터베이스가 모든 쓰기 작업을 수신하고 처리하는 마스터 서버 역할을 하고 다른 데이터베이스는 마스터 서버에서 데이터 업데이트를 요청하고 얻는 슬레이브 서버 역할을 하는 마스터-슬레이브 복제 모델을 기반으로 합니다. 데이터 복제는 마스터 서버의 바이너리 로그를 슬레이브 서버로 전송하여 수행됩니다.

  1. 마스터 서버 구성
    먼저 마스터 서버에서 바이너리 로그 기능을 활성화해야 합니다. my.cnf 구성 파일에 다음 콘텐츠를 추가합니다.

[mysqld]
server-id=1
log-bin=mysql-bin

여기서 server-id는 기본 서버의 고유 식별자이고 log- bin은 바이너리 로그 파일의 이름을 지정합니다.

그런 다음 구성을 적용하려면 MySQL 서비스를 다시 시작하세요.

  1. 슬레이브 서버 구성
    다음으로 슬레이브 서버에서 복제를 구성해야 합니다. my.cnf 구성 파일에 다음 콘텐츠를 추가합니다.

[mysqld]
server-id=2
relay-log=mysql-relay-bin
log-slave-updates=1

여기서 server-id는 서버의 고유 식별자인 Relay-log는 릴레이 로그 파일의 이름을 지정하고, log-slave-updates는 슬레이브 서버가 바이너리 로그를 기록하는지 여부를 나타냅니다.

그런 다음 구성을 적용하려면 MySQL 서비스를 다시 시작하세요.

  1. 복제 채널 설정
    마스터 서버에서 복제를 위한 전용 사용자를 생성하고 승인합니다.

CREATE USER 'replication'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON TO '. 복제'@'%';

그런 다음 다음 명령을 통해 마스터 서버에서 바이너리 로그 파일 이름과 위치를 가져옵니다.

SHOW MASTER STATUS;

슬레이브 서버에서 다음 명령을 실행하여 복제 채널을 설정합니다.

CHANGE MASTER TO MASTER_HOST='메인 서버 IP', MASTER_USER='복제', MASTER_PASSWORD='비밀번호', MASTER_LOG_FILE='바이너리 로그 파일 이름', MASTER_LOG_POS=location;

그런 다음 슬레이브 서버의 복제 기능을 시작합니다. :

START SLAVE ;

2. MySQL 데이터 동기화 구현 방법

MySQL 데이터 동기화는 여러 데이터베이스 간의 데이터를 일관되게 유지하여 데이터의 실시간성과 일관성을 보장하는 것을 의미합니다. 다음은 몇 가지 일반적인 데이터 동기화 구현 방법을 소개합니다.

    binlog 기반 데이터 동기화
  1. MySQL의 바이너리 로그는 데이터베이스의 모든 쓰기 작업을 기록합니다. 바이너리 로그를 사용하여 데이터 동기화를 달성할 수 있습니다. 구체적인 단계는 다음과 같습니다.
(1) 마스터 서버에서 바이너리 로그 기능을 활성화하고 binlog 형식을 ROW로 구성합니다.

binlog_format=ROW

(2) 슬레이브 서버에서 복제를 구성하고 CHANGE를 사용합니다. 복제 채널을 설정하고 복제를 시작하는 MASTER 명령입니다.

(3) 마스터 서버의 데이터가 변경되면 데이터를 동기화하기 위해 슬레이브 서버에 트리거를 만듭니다.

DELIMITER $$

CREATE TRIGGER sync_data AFTER INSERT ON 테이블 이름 FOR EACH ROW
BEGIN
INSERT INTO 테이블 이름 VALUES (NEW.field 1, NEW.field 2, ...);
END$$
DELIMITER ;

마스터 서버의 데이터가 변경되면 트리거는 슬레이브 서버에서 해당 INSERT 작업을 실행하여 데이터 동기화를 달성합니다.

    기본 키 자동 증가 열 기반 데이터 동기화
  1. 여러 데이터베이스 간에 데이터를 동기화할 때 기본 키 충돌이 자주 발생합니다. 한 가지 해결책은 기본 키 자동 증가 열을 사용하여 기본 키가 서로 다른 데이터베이스 간에 중복되지 않도록 하는 것입니다.
구체적인 단계는 다음과 같습니다.

(1) 각 데이터베이스에 테이블을 생성할 때 기본 키 필드를 자동 증가 열로 설정합니다.

(2) 각 데이터베이스에 데이터를 삽입할 때 기본 키 필드의 값을 지정할 필요가 없으며 데이터베이스는 자동으로 고유한 기본 키 값을 생성합니다.

(3) 예약된 작업 또는 트리거를 통해 각 데이터베이스의 데이터를 다른 데이터베이스에 동기화합니다.

코드 예:

CREATE TABLE 테이블 이름 (

id INT AUTO_INCREMENT PRIMARY KEY,
Field 1 VARCHAR(50),
Field 2 VARCHAR(50)
);

INSERT INTO 테이블 이름(필드 1, 필드 2) VALUES ('Data 1', 'Data 2');

    도구 기반 데이터 동기화
  1. binlog 및 기본 키 자동 증가 열을 기반으로 한 데이터 동기화 방법 외에도 다음을 달성할 수 있는 타사 도구도 있습니다. Maxwell 및 Debezium 등의 MySQL 데이터 동기화. 이러한 도구는 데이터베이스의 바이너리 로그를 구문 분석하고 이를 읽을 수 있는 형식으로 변환하여 데이터 동기화를 달성할 수 있습니다.
아직 코드 예제가 없습니다. 공식 문서와 도구 사용 예제를 참고하세요.

요약:

이 문서에서는 MySQL에서 데이터 복제 및 동기화를 수행하는 방법과 관련 코드 예제를 소개합니다. 데이터 복제 및 동기화를 통해 데이터베이스 및 데이터 보호의 고가용성을 달성하고 시스템의 안정성과 신뢰성을 향상시킬 수 있습니다. 동시에 실제 요구 사항에 따라 적절한 방법과 도구를 선택하면 비즈니스 요구 사항을 더 잘 충족할 수 있습니다.

위 내용은 MySQL에서 데이터 복제 및 동기화를 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.