>  기사  >  데이터 베이스  >  MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개

MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개

黄舟
黄舟원래의
2017-03-09 11:33:371941검색

MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개

MySQL 마스터-슬레이브 복제 일반적으로 데이터베이스를 설정합니다. 매개변수 구성 옵션인 binlog-do-db를 사용하여 동기화가 필요한 데이터베이스를 지정하면 마스터에서 동기화해야 하는 데이터베이스를 지정할 수 있고, 복제 do-db는 마스터의 데이터 지점에서 동기화해야 하는 데이터베이스를 지정합니다. 보다. (일반적으로 마스터에는 binlog-do-db만 설정되어 있으며, 동시에 설정할 필요는 없습니다. 혹시라도 슬레이브에 Replicate-ignore-db를 추가할 수도 있습니다.)

오늘 제가 겪은 문제는 마스터에 새로운 데이터베이스가 추가되는 것이었습니다. MySQL의 마스터-슬레이브 복제 체인에 새로 추가된 데이터베이스를 어떻게 추가하나요? (즉, 전체 라이브러리를 다시 복제하지 않고 마스터-슬레이브 복제를 재설정합니다.)

먼저 마스터-슬레이브 복제의 기본 단계를 열거해 보겠습니다(MySQL 마스터-슬레이브는 먼저 해당 서버에서 구성되어야 합니다).

1. 데이터베이스 복사


mysqldump --master-data --single-transaction -R --databases [db_name] | gzip -9 - | pv > all-db-with-master-data.sql.gz

참고: innodb는 –single-transaction을 사용하고, myisam은 –lock-all-tables를 사용해야 합니다.

2. 데이터 복사 및 가져오기

rree

3. 슬레이브 데이터베이스를 시작합니다.

pv < all-db-with-master-data.sql.gz | zcat | mysql

참고: 내보낸 SQL 문에 메인으로 전환하는 문이 이미 있으므로 주의 깊게 확인하시기 바랍니다. 마스터를 master_log_file='(relay_master_log_file의 binlog 이름)', master_log_pos=(exec_master_log_pos 번호)로 변경합니다.
그렇다면 기존 마스터-슬레이브 복제 구조에 어떻게 새로운 데이터베이스를 추가할 수 있을까요? 예를 들어, 마스터 서버에 newdb라는 데이터베이스를 추가하려고 합니다. 구체적인 작업은 다음과 같습니다.

1. 서비스에서 슬레이브 데이터베이스를 중지합니다.

slave start

2. 메인 서버에서 새 데이터베이스를 내보냅니다.

stop slave;

3. 메인 서버에서 my.cnf 파일을 수정합니다.

메인 서버에서 my.cnf 파일을 수정하고, binlog-do-db 매개변수에 새 라이브러리를 추가합니다. 그리고 mysql을 다시 시작하세요.

4. 현재 로그 파일과 위치를 찾습니다

내보낸 newdb.sql에서 현재 로그 파일과 위치를 찾습니다(마스터를…으로 변경)
. 서버는 이 위치에서 실행됩니다.

mysqldump --master-data --single-transaction -R --databases newdb > newdb.sql

그 중 MASTER_LOG_FILE, MASTER_LOG_POS가 내보낸 데이터베이스 newdb.sql 상위에서 검색됩니다.

5. 새 라이브러리를 슬레이브 서버로 가져옵니다.

start slave until MASTER_LOG_FILE="mysql-bin.000001", MASTER_LOG_POS=1222220;

6. 슬레이브 서버 시작

mysql < newdb.sql

더 중요한 것은 마스터 서버에 새 라이브러리를 내보낼 때 로그 위치(위치 A)입니다. 경계선으로 가리키고 새 라이브러리를 가져옵니다.
이 방법은 특정 데이터베이스 또는 특정 데이터 테이블이 동기화되지 않은 상황에도 적용 가능합니다. 예를 들어 마스터-슬레이브 데이터베이스의 테이블에 어떤 이유로 인해 데이터가 일치하지 않는 경우 위 방법만 있으면 됩니다. 데이터베이스를 재시작하는 단계를 없애고 나머지 작업은 기본적으로 동일합니다


위 내용은 MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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