the master's binary log is corrupted

orclwujian發表於2016-10-18
主從複製報錯,下面是從庫複製狀態:
mysql> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.129.150
                  Master_User: replicat
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000197
          Read_Master_Log_Pos: 213271941
               Relay_Log_File: mysql-relay-bin.000584
                Relay_Log_Pos: 1037392990
        Relay_Master_Log_File: mysql-bin.000195
             Slave_IO_Running: Yes
            Slave_SQL_Running: No
...
                   Last_Errno: 1594
                   Last_Error: Relay log read failure: Could not parse relay log event entry. The possible reasons are: the master's binary log is corrupted (you can check this by running 'mysqlbinlog' on the binary log), the slave's relay log is corrupted (you can check this by running 'mysqlbinlog' on the relay log), a network problem, or a bug in the master's or slave's MySQL code. If you want to check the master's binary log or slave's relay log, you will be able to know their names by issuing 'SHOW SLAVE STATUS' on this slave.
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 1037392827
              Relay_Log_Space: 2368588837
...
               Last_SQL_Errno: 1594
               Last_SQL_Error: Relay log read failure: Could not parse relay log event entry. The possible reasons are: the master's binary log is corrupted (you can check this by running 'mysqlbinlog' on the binary log), the slave's relay log is corrupted (you can check this by running 'mysqlbinlog' on the relay log), a network problem, or a bug in the master's or slave's MySQL code. If you want to check the master's binary log or slave's relay log, you will be able to know their names by issuing 'SHOW SLAVE STATUS' on this slave.
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 3
                  Master_UUID: 58c0c354-8652-11e6-bebe-40f2e9ddc532
             Master_Info_File: /data/DB/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: 161018 09:38:49
....
中繼日誌讀主庫日誌失敗 ,順道看下錯誤日誌資訊,日誌顯示從庫9點37分時重啟了,38分出現主從故障,看樣子是因為從庫異常重啟導致的!
161018 09:37:39 mysqld_safe Number of processes running now: 0
161018 09:37:39 mysqld_safe mysqld restarted
...
2016-10-18 09:38:49 6042 [ERROR] Slave SQL: Relay log read failure: Could not parse relay log event entry. The possible reasons are: the master's binary log is corrupted (you can check this by running 'mysqlbinlog' on the binary log), the slave's relay log is corrupted (you can check this by running 'mysqlbinlog' on the relay log), a network problem, or a bug in the master's or slave's MySQL code. If you want to check the master's binary log or slave's relay log, you will be able to know their names by issuing 'SHOW SLAVE STATUS' on this slave. Error_code: 1594

解決方法,重新設定主從程式解決:
mysql> stop slave;
Query OK, 0 rows affected (0.02 sec)

mysql> reset slave;
Query OK, 0 rows affected (0.57 sec)

mysql> change master to master_host='192.168.129.150',
    -> master_user='replicat',
    -> master_password='passw',
    -> master_log_file='mysql-bin.000195',
    -> master_log_pos=1037392827;
Query OK, 0 rows affected, 2 warnings (0.07 sec)

mysql> start slave;
Query OK, 0 rows affected (0.03 sec)

以前從庫異常重啟都沒發生這類情況,網上查了相關資料,發現和relay_log_info_repository和relay_log_info_repository這兩個引數有關
mysql> show variables like '%relay_log_info_repository%';
+---------------------------+-------+
| Variable_name             | Value |
+---------------------------+-------+
| relay_log_info_repository | FILE  |
+---------------------------+-------+
1 row in set (0.00 sec)

mysql> show variables like '%relay_log_info_repository%';
+---------------------------+-------+
| Variable_name             | Value |
+---------------------------+-------+
| relay_log_info_repository | FILE  |
+---------------------------+-------+
1 row in set (0.00 sec)
把FILE修改成TABLE可以降低這種主從失敗發生的機率。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29989552/viewspace-2126637/,如需轉載,請註明出處,否則將追究法律責任。

相關文章