>  기사  >  데이터 베이스  >  mysql 마스터-슬레이브 동기화 오류를 건너뛰는 방법

mysql 마스터-슬레이브 동기화 오류를 건너뛰는 방법

coldplay.xixi
coldplay.xixi원래의
2021-01-06 11:19:196567검색

mysql 마스터-슬레이브 동기화에서 오류를 건너뛰는 방법: 1. 지정된 수의 트랜잭션을 건너뛰고 코드는 [mysql>SET GLOBAL SQL_SLAVE_SKIP..]입니다. 2. mysql 구성 파일을 수정하고 [slave_skip_errors를 통해 모든 오류를 건너뜁니다. ] 매개변수 .

mysql 마스터-슬레이브 동기화 오류를 건너뛰는 방법

이 튜토리얼의 운영 환경: windows7 시스템, mysql 버전 5.6.14, DELL G3 컴퓨터 이 방법은 모든 브랜드의 컴퓨터에 적합합니다.

관련 무료 학습 권장사항: mysql 비디오 튜토리얼

Mysql 마스터-슬레이브 동기화 건너뛰기 오류 방법:

1 지정된 트랜잭션 수 건너뛰기:

mysql>slave stop;
mysql>SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1        #跳过一个事务
mysql>slave start

2. 모든 오류 또는 지정된 유형의 오류를 건너뛰는slave_skip_errors 매개변수slave_skip_errors参数来跳所有错误或指定类型的错误

vi /etc/my.cnf
[mysqld]
#slave-skip-errors=1062,1053,1146  #跳过指定error no类型的错误
#slave-skip-errors=all  #跳过所有错误

例:下面模拟一个错误场景

环境(一个已经配置好的主从复制环境)

master数据库IP:192.168.247.128

slave数据库IP:192.168.247.130

mysql版本:5.6.14

binlog-do-db = mydb

在master上执行以下语句:

mysql>use mysql;
mysql>create table t1 (id int);
mysql>use mydb;
mysql>insert into mysql.t1 select 1;

在slave上查看复制状态

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.247.128
                  Master_User: repl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000017
          Read_Master_Log_Pos: 2341
               Relay_Log_File: DBtest1-relay-bin.000011
                Relay_Log_Pos: 494
        Relay_Master_Log_File: mysql-bin.000017
             Slave_IO_Running: Yes
            Slave_SQL_Running: No
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
                   Last_Errno: 1146
                   Last_Error: Error 'Table 'mysql.t1' doesn't exist' on query. Default database: 'mydb'. Query: 'insert into mysql.t1 select 1'
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 1919
              Relay_Log_Space: 1254
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error: 
               Last_SQL_Errno: 1146
               Last_SQL_Error: Error 'Table 'mysql.t1' doesn't exist' on query. Default database: 'mydb'. Query: 'insert into mysql.t1 select 1'
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1
                  Master_UUID: f0f7faf6-51a8-11e3-9759-000c29eed3ea
             Master_Info_File: /var/lib/mysql/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: 
           Master_Retry_Count: 86400
                  Master_Bind: 
      Last_IO_Error_Timestamp: 
     Last_SQL_Error_Timestamp: 131210 21:37:19
               Master_SSL_Crl: 
           Master_SSL_Crlpath: 
           Retrieved_Gtid_Set: 
            Executed_Gtid_Set: 
                Auto_Position: 0
1 row in set (0.00 sec)

由结果可以看到,Read_Master_Log_Pos: 2341,Exec_Master_Log_Pos: 1919时出错了Last_SQL_Error: Error 'Table 'mysql.t1' doesn't exist' on queryrrreee

예: 다음은 오류 시나리오

환경(구성된 마스터-슬레이브 복제 환경)🎜🎜마스터 데이터베이스 IP: 192.168.247.128 🎜🎜slave를 시뮬레이션합니다. 데이터베이스 IP: 192.168.247.130🎜🎜mysql 버전: 5.6.14🎜🎜binlog-do-db = mydb🎜🎜마스터에서 다음 문을 실행합니다.🎜rrreee🎜슬레이브에서 복제 상태 보기🎜rrreee🎜결과는 다음과 같습니다. Read_Master_Log_Pos: 2341, Exec_Master_Log_Pos: 1919에서 Last_SQL_Error: 쿼리에 '테이블 'mysql.t1'이 존재하지 않습니다'라는 오류가 발생했습니다를 참조하세요.🎜🎜Mydb에만 해당되기 때문입니다. mydb 라이브러리에 있는 다른 데이터베이스의 테이블을 조작할 때, 해당 테이블이 슬레이브에 존재하지 않으면 오류가 발생합니다. 🎜

위 내용은 mysql 마스터-슬레이브 동기화 오류를 건너뛰는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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