mysql GTID复制跳过复制错误的方式有哪些

技术mysql GTID复制跳过复制错误的方式有哪些这篇文章主要介绍mysql GTID复制跳过复制错误的方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、从库执行了事务,主库执行语句时

本文主要介绍mysql GTID复制中跳过复制错误的方法。很详细,有一定的参考价值。感兴趣的朋友一定要读出来!

1.从库执行事务,主库在执行语句时导致冲突:

解决方案1:跳过错误(推荐几个错误)

(1)停止从进程

(2)设置交易号,从Executed_Gtid_Set交易号1获取,即跳过当前执行的下一个交易,在进程中设置GTID_next,即跳过这个Gtid。

(3)执行空的东西。

(4)恢复自动交易号。

(5)启动从进程。

mysql STOP SLAVE

mysql SET @@SESSION。GTID _ NEXT=' 8f 9e 146 f-0a 18-11e 7-810 a-0050568833 c 8:4 ';

mysql BEGINCOMMIT

MySQL SET SESSION GTID _ NEXT=AUTOMATIC;

mysql START SLAVE

解决方案2:复位主方法跳过错误(不推荐,因为需要执行复位主;如果其他节点记录了该实例的位置信息,则在切换时需要再次查找位置)

mysql STOP SLAVE

mysql RESET MASTER

mysql SET @@GLOBAL。GTID _ PURGED=' 8f 9e 146 f-0a 18-11e 7-810 a-0050568833 c 8:1-4 ';

mysql START SLAVE

上述命令的目的是忽略8f9e 146 f-0a 18-11e 7-810 a-0050568833 c 8:1-4的GTID事务,下一个事务将以5的GTID开始,这样可以跳过上述错误。

解决方案3:使用pt-slave-restart工具,忽略具体错误,(有很多冲突时可以使用,建议保留relaylog检查事务),

pt-SLAVE-restart工具用于监视一些特定的复制错误,然后忽略它们并再次启动SLAVE进程(在出现错误后观察并重新启动MySQL复制)。

pt从动重启工具的原理

1.检查版本信息和兼容性。

设置自动提交=1

显示变量,如“等待\u超时”

设置会话等待超时=10000

选择@@SQL_MODE

SET @@SQL_QUOTE_SHOW_CREATE=1/*!40101,@ @ SQL _ MODE=' NO _ AUTO _ VALUE _ ON _ ZERO,NO _ ENGINE _ replacement ' */

选择@@SERVER_ID

显示从属状态

选择CONcat(@ @主机名,@ @端口)

像版本%一样显示变量

显示引擎

显示变量,如' innodb_version '

选择@ @全局。GTID_mode(是否开启GTID决定如何跳过交易)

选择@ @ global . slave _ parallel _ workers作为线程(不支持并行复制)

2.检查同步错误。

显示从属状态;

如果使用- error-numbers,请检查Last_SQL_Errno:错误号以确定它是否匹配;如果匹配继续,不要做任何不匹配的事情。

如果使用- error-text,检查Last_SQL_Error:的错误内容,确定是否匹配;如果匹配继续,不要做任何不匹配的事情。

3.跳过交易

SET GTID _ NEXT=' 026 b75 e 5-d99f-11e 7-a343-000 c29 DC 5 F5 c :2023 ';

设置自动提交=0;

提交;

设置自动提交=1;

设置GTID_NEXT=“自动”;

开始从机;

4.继续判断状态,如有错误,继续步骤2、3、4。

显示从属状态;

mysql显示从属状态\G

*************************** 1.行**************************

从机输入输出状态:等待主机发送事件

                  Master_Host: 192.168.137.101
                  Master_User: repluser
                  Master_Port: 3307
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000003
          Read_Master_Log_Pos: 3435
               Relay_Log_File: mysql-relay-bin.000016
                Relay_Log_Pos: 1026
        Relay_Master_Log_File: mysql-bin.000003
             Slave_IO_Running: Yes
            Slave_SQL_Running: No
  Replicate_Wild_Ignore_Table: passport.cooke,passport.user_token,sysbench_test.sbtest1,sysbench_test.sbtest_1
                   Last_Errno: 1062
                   Last_Error: Error 'Duplicate entry '9' for key 'PRIMARY'' on query. Default database: 'test'. Query: 'insert into backup_test (id,backup_que) values(9,'1_111')'
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 2856
              Relay_Log_Space: 2362
               Last_SQL_Errno: 1062
               Last_SQL_Error: Error 'Duplicate entry '9' for key 'PRIMARY'' on query. Default database: 'test'. Query: 'insert into backup_test (id,backup_que) values(9,'1_111')'
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 1013307
                  Master_UUID: 026b75e5-d99f-11e7-a343-000c29dc5f5c
             Master_Info_File: mysql.slave_master_info
     Last_SQL_Error_Timestamp: 180504 11:58:07
           Retrieved_Gtid_Set: 026b75e5-d99f-11e7-a343-000c29dc5f5c:1004-2018
            Executed_Gtid_Set: 026b75e5-d99f-11e7-a343-000c29dc5f5c:1-2016,
5f5c73b5-2768-11e8-9e7e-000c298bd943:1-2997,
68be50a9-3ba1-11e8-a25d-000c298bd943:1-4
                Auto_Position: 1

[root@vm102 yum.repos.d]# pt-slave-restart  --user=mg -h227.0.0.1 -P3307 -p123qwe  --error-numbers=1062
2018-05-04T11:47:31 P=3307,h=127.0.0.1,p=...,u=mg mysql-relay-bin.000016         448 1062 
2018-05-04T11:47:31 P=3307,h=127.0.0.1,p=...,u=mg mysql-relay-bin.000016         737 1062 

[root@vm102 yum.repos.d]# pt-slave-restart  --user=mg -h227.0.0.1 -P3307 -p123qwe  --error-text="backup_test" 
2018-05-04T12:00:23 P=3307,h=127.0.0.1,p=...,u=mg mysql-relay-bin.000016        1026 1062 
2018-05-04T12:00:24 P=3307,h=127.0.0.1,p=...,u=mg mysql-relay-bin.000016        1315 1062 

参数解释:
 --slave-password=s     Sets the password to be used to connect to the slaves
  --slave-user=s         Sets the user to be used to connect to the slaves
  --sleep=i              Initial sleep seconds between checking the slave ( default 1)
  --socket=s         -S  Socket file to use for connection=
--password=s       -p  Password to use when connecting
pt-slave-resetart  -S./mysql.sock —error-numbers=1032
 --error-numbers=h      Only restart this comma-separated list of errors
 --host=s           -h  Connect to host
 --user=s           -u  User for login if not current user

以上是“mysql GTID复制跳过复制错误的方式有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/73749.html

(0)

相关推荐

  • Django ManyToManyField 跨越中间表查询的方法是什么

    技术Django ManyToManyField 跨越中间表查询的方法是什么本篇文章为大家展示了Django ManyToManyField 跨越中间表查询的方法是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过

    攻略 2021年11月30日
  • 数据库单库备份sh的方法是什么

    技术数据库单库备份sh的方法是什么本篇内容主要讲解“数据库单库备份sh的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库单库备份sh的方法是什么”吧! 实例代码

    攻略 2021年11月16日
  • 生成器与常见内置函数

    技术生成器与常见内置函数 生成器与常见内置函数异常捕获补充
    # 异常捕获的完整形式
    try:name
    except NameError as e:pass
    except Exception as e:p

    礼包 2021年11月23日
  • shotcut用什么剪辑(shotcut实用功能)

    技术Shotcut有什么用小编给大家分享一下Shotcut有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Shotcut是一个免费、开放

    攻略 2021年12月24日
  • Adaptive Cursor Sharing分析

    技术Adaptive Cursor Sharing分析这篇文章主要讲解了“Adaptive Cursor Sharing分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“

    攻略 2021年11月15日
  • SqlServer Mysql数据库修改自增列的值及相应问题的解决方案是怎样的

    技术SqlServer Mysql数据库修改自增列的值及相应问题的解决方案是怎样的今天就跟大家聊聊有关SqlServer Mysql数据库修改自增列的值及相应问题的解决方案是怎样的,可能很多人都不太了解,为了让大家更加了

    攻略 2021年11月30日