MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개
MySQL 마스터-슬레이브 복제 일반적으로 데이터베이스를 설정합니다. 매개변수 구성 옵션인 binlog-do-db를 사용하여 동기화가 필요한 데이터베이스를 지정하면 마스터에서 동기화해야 하는 데이터베이스를 지정할 수 있고, 복제 do-db는 마스터의 데이터 지점에서 동기화해야 하는 데이터베이스를 지정합니다. 보다. (일반적으로 마스터에는 binlog-do-db만 설정되어 있으며, 동시에 설정할 필요는 없습니다. 혹시라도 슬레이브에 Replicate-ignore-db를 추가할 수도 있습니다.)
오늘 제가 겪은 문제는 마스터에 새로운 데이터베이스가 추가되는 것이었습니다. MySQL의 마스터-슬레이브 복제 체인에 새로 추가된 데이터베이스를 어떻게 추가하나요? (즉, 전체 라이브러리를 다시 복제하지 않고 마스터-슬레이브 복제를 재설정합니다.)
먼저 마스터-슬레이브 복제의 기본 단계를 열거해 보겠습니다(MySQL 마스터-슬레이브는 먼저 해당 서버에서 구성되어야 합니다).
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를 사용해야 합니다.
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라는 데이터베이스를 추가하려고 합니다. 구체적인 작업은 다음과 같습니다.
slave start
stop slave;
메인 서버에서 my.cnf 파일을 수정하고, binlog-do-db 매개변수에 새 라이브러리를 추가합니다. 그리고 mysql을 다시 시작하세요.
내보낸 newdb.sql에서 현재 로그 파일과 위치를 찾습니다(마스터를…으로 변경)
. 서버는 이 위치에서 실행됩니다.
mysqldump --master-data --single-transaction -R --databases newdb > newdb.sql
그 중 MASTER_LOG_FILE, MASTER_LOG_POS가 내보낸 데이터베이스 newdb.sql 상위에서 검색됩니다.
start slave until MASTER_LOG_FILE="mysql-bin.000001", MASTER_LOG_POS=1222220;
mysql < newdb.sql
더 중요한 것은 마스터 서버에 새 라이브러리를 내보낼 때 로그 위치(위치 A)입니다. 경계선으로 가리키고 새 라이브러리를 가져옵니다.
이 방법은 특정 데이터베이스 또는 특정 데이터 테이블이 동기화되지 않은 상황에도 적용 가능합니다. 예를 들어 마스터-슬레이브 데이터베이스의 테이블에 어떤 이유로 인해 데이터가 일치하지 않는 경우 위 방법만 있으면 됩니다. 데이터베이스를 재시작하는 단계를 없애고 나머지 작업은 기본적으로 동일합니다
위 내용은 MySQL - MySQL 마스터-슬레이브 복제 목록에 새 데이터베이스를 추가하는 방법에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!