暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

mysql主从同步故障解决

程序老哥 2021-07-11
1163

一、报错现象

在一台机器上启动slave,启动命令和报错信息如下:


    mysql> start slave;
    ERROR 1872 (HY000): Slave failed to initialize relay log info structure from the repository

    从报错上看,意思是启动slave时,使用repository中信息初始化relay log结构失败了。为什么失败了?那如何解决呢?先来简单的了解MySQL Relay log的基础知识。


    1

    MySQL Relay log介绍

    在MySQL复制结构下,Slave服务器会产生三种日志文件,用来保存主库的二进制日志事件以及relay log已执行到的位置和状态。

    • relay log 文件:由IO thread线程从主库读取的二进制日志事件组成,该日志被Slave上的SQL thread线程执行,从而实现数据的复制。

    • master info log:该文件保存slave连接master的状态以及配置信息,如用户名,密码,日志执行的位置等。在5.6版本之前,都是使用master.info文件,从5.6开始,通过在my.cnf 中配置 --master-info-repository=TABLE。这些信息会被写入mysql.slave_master_info 表中,代替原来的master.info文件了。

    • relay log info log:该文件保存slave上relay log的执行位置。在5.6版本之前,都是使用relay-log.info文件,从5.6开始,通过在my.cnf中配置 --relay-log-info-repository=TABLE,使用mysql.slave_relay_log_info表代替原来的文件。每次当slave上执行start slave时,就会读取该表中的位置信息。


    新版本使用表来代替原来的文件,主要为了crash-safe replication,从而大大提高从库的可靠性。为了保证意外情况下从库的可靠性,mysql.slave_master_info和mysql.slave_relay_log_info表必须为事务性的表,从5.6.6起,这些表默认使用InnoDB存储引擎。在5.6.5及之前的版本默认使用MyISAM引擎,可用下面语句进行转换:

      ALTER TABLE mysql.slave_master_info ENGINE=InnoDB;
      ALTER TABLE mysql.slave_relay_log_info ENGINE=InnoDB;
      【注意】不要试图手工的更新、插入、删除以上两个表的内容,以免出现意料不到的问题。


      2

      解决方法

      reset slave命令包含的动作有:

      1. 删除slave_master_info ,slave_relay_log_info两个表中数据;

      2. 删除所有relay log文件,并重新创建新的relay log文件;

      3. 不会改变gtid_executed 或者 gtid_purged的值

      具体操作如下:

      • 在Master(主)所在机器执行

        mysql> show master status;
        +------------------+----------+--------------+---------------------------------------------+-------------------+
        | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
        +------------------+----------+--------------+---------------------------------------------+-------------------+
        | mysql-bin.000011 | 95728 | | mysql,information_schema,performance_schema | |
        +------------------+----------+--------------+---------------------------------------------+-------------------+
        1 row in set (0.00 sec)


        • 在Slave(从)所在机器执行

          mysql> reset slave;                           
          mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.98',
          MASTER_USER='backup',
          MASTER_PASSWORD='123456',
          MASTER_PORT=3306,
          MASTER_LOG_FILE='mysql-bin.000021',
          MASTER_LOG_POS=129691330;
          mysql> start slave;
          mysql> show slave status\G


          到这里问题解决了。

          以图为正,主从关系建立成功,正在同步中。


          /

          /

          / 微信号 / 程序老哥/

          文章转载自程序老哥,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

          评论