资讯专栏INFORMATION COLUMN

MySQL主从复制遇到错误的处理办法

Steve_Wang_ / 996人阅读

摘要:在主从复制的时候经常遇到错误而导致复制中断,这个时候就需要人工干涉,来跳过这个错误,才能使端的复制,得以继续进行跳过错误的方法例如错误发生时的状态使用上面的方法使的端复制恢复正常到此,的主从复制恢复正常。。。

MySQL在主从复制的时候经常遇到错误而导致Slave复制中断,这个时候就需要人工干涉,来跳过这个错误,才能使Slave端的复制,得以继续进行;

跳过错误的方法:

MariaDB [(none)]> STOP SLAVE;
MariaDB [(none)]> SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
MariaDB [(none)]> SHOW GLOBAL VARIABLES LIKE "SQL_SLAVE_SKIP_COUNTER";

+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| sql_slave_skip_counter | 1     |
+------------------------+-------+

MariaDB [(none)]> START SLAVE;

例如:
Slave错误发生时的状态:

MariaDB [(none)]> SHOW SLAVE STATUSG
*************************** 1. row ***************************
           Slave_IO_State: Waiting for master to send event
              Master_Host: 192.168.180.100
              Master_User: repluser
              Master_Port: 3306
            Connect_Retry: 60
          Master_Log_File: mysql-bin.000004
      Read_Master_Log_Pos: 658
           Relay_Log_File: relay-bin.000002
            Relay_Log_Pos: 601
    Relay_Master_Log_File: mysql-bin.000001
         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: 1008
               Last_Error: Error "Can"t drop database "test"; database doesn"t exist" on query. Default database: "test". Query: "drop database test"
             Skip_Counter: 0
      Exec_Master_Log_Pos: 313
          Relay_Log_Space: 4079
          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: 1008
           Last_SQL_Error: Error "Can"t drop database "test"; database doesn"t exist" on query. Default database: "test". Query: "drop database test"
  Replicate_Ignore_Server_Ids: 
         Master_Server_Id: 1
           Master_SSL_Crl: 
       Master_SSL_Crlpath: 
               Using_Gtid: No
              Gtid_IO_Pos: 
  Replicate_Do_Domain_Ids: 
  Replicate_Ignore_Domain_Ids: 
            Parallel_Mode: conservative
            

使用上面的方法使MySQL的Slave端复制恢复正常:

MariaDB [(none)]> STOP SLAVE;
MariaDB [(none)]> SET GLOBAL  SQL_SLAVE_SKIP_COUNTER=1;
MariaDB [(none)]> SHOW GLOBAL VARIABLES LIKE "SQL_SLAVE_SKIP_COUNTER";
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| sql_slave_skip_counter | 1     |
+------------------------+-------+
MariaDB [(none)]> START SLAVE;
MariaDB [(none)]> SHOW SLAVE STATUSG
*************************** 1. row ***************************
           Slave_IO_State: Waiting for master to send event
              Master_Host: 192.168.180.100
              Master_User: repluser
              Master_Port: 3306
            Connect_Retry: 60
          Master_Log_File: mysql-bin.000004
      Read_Master_Log_Pos: 658
           Relay_Log_File: relay-bin.000006
            Relay_Log_Pos: 537
    Relay_Master_Log_File: mysql-bin.000004
         Slave_IO_Running: Yes
        Slave_SQL_Running: Yes
          Replicate_Do_DB: 
      Replicate_Ignore_DB: 
       Replicate_Do_Table: 
   Replicate_Ignore_Table: 
  Replicate_Wild_Do_Table: 
  Replicate_Wild_Ignore_Table: 
               Last_Errno: 0
               Last_Error: 
             Skip_Counter: 0
      Exec_Master_Log_Pos: 658
          Relay_Log_Space: 1526
          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: 0
Master_SSL_Verify_Server_Cert: No
            Last_IO_Errno: 0
            Last_IO_Error: 
           Last_SQL_Errno: 0
           Last_SQL_Error: 
  Replicate_Ignore_Server_Ids: 
         Master_Server_Id: 1
           Master_SSL_Crl: 
       Master_SSL_Crlpath: 
               Using_Gtid: No
              Gtid_IO_Pos: 
  Replicate_Do_Domain_Ids: 
  Replicate_Ignore_Domain_Ids: 
            Parallel_Mode: conservative
            

到此,MySQL的主从复制恢复正常。。。大功告成

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/49290.html

相关文章

  • mysql

    摘要:安装软件包和软件包安装的依赖包,在所有的服务器上在作为监控的服务器上,要需额外安装注意我是通过安装的,但是在的仓库并没有所有的安装包。 一.安装mysql yum install wgetwget http://repo.mysql.com/mysql57-community-release-el7-8.noarch.rpmyum localinstall mysql57-commu...

    ityouknow 评论0 收藏0
  • mysql

    摘要:安装软件包和软件包安装的依赖包,在所有的服务器上在作为监控的服务器上,要需额外安装注意我是通过安装的,但是在的仓库并没有所有的安装包。 一.安装mysql yum install wgetwget http://repo.mysql.com/mysql57-community-release-el7-8.noarch.rpmyum localinstall mysql57-commu...

    MrZONT 评论0 收藏0
  • MySQL数据库运维之主从复制搭建

    摘要:上篇文章详细介绍了数据库的单机多实例搭建,本篇文章将在上篇文章的基础上介绍主从复制过程,其中常见的复制架构有异步复制,半同步复制及同步复制。 上篇文章详细介绍了MySQL数据库的单机多实例搭建,本篇文章将在上篇文章的基础上介绍MySQL主从复制过程,其中常见的复制架构有:异步复制,半同步复制及同步复制。常用的复制架构有异步复制及半同步复制! 一、常见的复制架构 1、主主复制(1)结构图...

    ad6623 评论0 收藏0
  • 面试官:咱们来聊一聊mysql主从延迟

    摘要:编辑器编辑器背景编辑器前段时间遇到一个线上问题,后来排查好久发现是因为主从同步延迟导致的,所以今天写一篇文章总结一下这个问题希望对你有用。编辑器几句唠叨编辑器大家好,我是小饭,一枚后端工程师。背景前段时间遇到一个线上问题,后来排查好久发现是因为主从同步延迟导致的,所以今天写一篇文章总结一下这个问题希望对你有用。如果觉得还不错,记得加个关注点个赞哦思维导图思维导图常见的主从架构随着日益增长的访...

    EasonTyler 评论0 收藏0
  • mysql 主从分离原理及mycat配置

    摘要:在事件写入二进制日志完成后,通知存储引擎提交事务。从线程处理该过程的最后一步。线程从中继日志读取事件,并重放其中的事件而更新的数据,使其与中的数据一致。参数说明选项有四个可用值,分别为,,,。 1.1 mysql支持的复制类型:   基于语句的复制:在主服务器上执行的SQL语句,在从服务器上执行同样的语句。MySQL默认采用基于语句的复制,效率比较高。一旦发现没法精确复制时,会自动选...

    fengxiuping 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<