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)

相关推荐

  • 怎么理解UML

    技术怎么理解UML今天就跟大家聊聊有关怎么理解UML,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。什么是UML?Unified Modeling Language

    攻略 2021年11月23日
  • 手机掉水里马上捞起来会进水吗,苹果七掉进水里会进水么

    技术手机掉水里马上捞起来会进水吗,苹果七掉进水里会进水么一旦iphone进水手机掉水里马上捞起来会进水吗,按以下步骤处理:1、以最快速度把iphone从水里把它捞出来。2、立即关掉iPhone。马上断开电源。因为手机的损

    2021年10月21日
  • 如何配置Hibernate

    技术如何配置Hibernate本篇内容主要讲解“如何配置Hibernate”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何配置Hibernate”吧!当我们有了一个持久化类

    攻略 2021年12月4日
  • ARCHIVELOG如何统计归档日志更准确

    技术ARCHIVELOG如何统计归档日志更准确小编给大家分享一下ARCHIVELOG如何统计归档日志更准确,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了

    攻略 2021年12月10日
  • 令字加偏旁,“令”加什么偏旁变成新字

    技术令字加偏旁,“令”加什么偏旁变成新字令字可以加令字加偏旁: 冫偏旁,组词新字是:冷。令字可以加: 山偏旁,组词新字是:岭。令字可以加: 王偏旁,组词新字是:玲。令字可以加:亻偏旁,组词新字是:伶。冷拼音:lěng

    生活 2021年10月28日
  • 13. 罗马数字转整数

    技术13. 罗马数字转整数 13. 罗马数字转整数罗马数字包含以下七种字符:I,V,X,L,C,D和M。
    字符 数值
    I 1
    V 5
    X

    礼包 2021年12月2日