当前位置:Gxlcms > 数据库问题 > (5.11)mysql高可用系列——复制中常见的SQL与IO线程故障

(5.11)mysql高可用系列——复制中常见的SQL与IO线程故障

时间:2021-07-01 10:21:17 帮助过:12人阅读

.1】先在从库上创建一个用户,再去主库上创建一个用户
-- 从202:       
create user ‘test‘@‘%‘ identified by ‘123456‘;
grant all privileges on *.* to ‘test‘@‘%‘;
flush privileges;

-- 主202:       
create user ‘test‘@‘%‘ identified by ‘123456‘;
grant all privileges on *.* to ‘test‘@‘%‘;
flush privileges;

use test;
create table test3(id int);
insert into test3 values(1);
commit;

【1.1.2】核验同步

发现不同步
技术图片技术图片

 

在从库202执行:

 show slave status\G  -- 查看状态

 发现错误:

技术图片

这里显示的GTID,指的是,需要执行这个GTID事务失败了,也就是说,真正出问题的是该GTID上面那个事务。

 

 【1.1.3】核验错误信息

根据图上的文件名和位置在主库上查看执行的信息是什么;

 果然是创建用户报错了。

 技术图片

  从这个图,根据位置信息和GTID,应该就可以应征上面标红说的。

 查看更详细的信息;在从库上运行

  select * from performance_schema.replication_applier_status_by_worker\G

  技术图片

  Read_Master_Log_Pos: 2174

  Exec_Master_Log_Pos: 1112

技术图片

 

 记得,这个错误号,就是我们报错的那个,要对应否则可能是其他时间出现的错误信息;

【1.1.4】解决,跳过、屏蔽这个冲突事务

在从库上:直接指定,下一个执行的事务,为错误信息上显示的事务(因为这里显示的GTID,是说执行到这个点出错,这个GTID所在的事务没有执行

(1)由于在这个GTID必须是连续的,正常情况同一个服务器产生的GTID是不会存在空缺的。

   所以不能简单的skip掉一个事务,只能通过注入空事物的方法替换掉一个实际操作事务。

(2)注入空事物的方法:

stop slave;

set @@session.gtid_next=‘de853101-b165-11e9-900a-000c291f4171:8‘;

start slave;

set @@session.gtid_next=‘automatic‘; -- 不改回来,很多报错

 

  如果这时候,报错,或者最后一个设置 set @@session.gtid_next=‘automatic‘; 的时候报错。

  可以构造一个空事务。  begin;commit;  然后再次 set @@session.gtid_next=‘automatic‘;

  技术图片

 

 

 

 

【1.1.5】核验

  show slave status\G -- 查看进程状态与错误信息 是否OK

  use test;show tables; -- 查看数据是否同步过来,OK了啊

  技术图片

 

 【1.1.6】如果是主库的最后一条事务报错,怎么办?

 

 

(5.11)mysql高可用系列——复制中常见的SQL与IO线程故障

标签:出错   io线程   code   注入   height   技术   操作   ast   values   

人气教程排行