mysql大事务导致主从延时处理
admin
2024-03-23 03:23:16

show slave status\G

Slave_SQL_Running_State: Waiting for dependent transaction to commit

Slave_SQL_Running_State: Waiting for Slave Worker queue

Slave_SQL_Running_State: Waiting for Slave Workers to free pending events

1、执行sql检查是否有长事务没有提交?

select * from information_schema.INNODB_TRX i, information_schema.processlist p where i.trx_mysql_thread_id=p.id and p.time > 60;

2、查看是否开启gtid

show variables like '%gtid%';

3、stop slave;如果停止不了,可以kill大事务线程再执行stop slave

4、如果开启了gtid,那么执行:

stop slave;
set global slave_pending_jobs_size_max=16777216*32;
set global slave_parallel_workers=16;
set global max_allowed_packet=67108864*2;
start slave;

或跳过这个大事务

stop slave;
SET @@SESSION.GTID_NEXT= '7a240e0a-b937-11ea-990c-00e0ed87fc72:848358386';
begin;commit;
set session gtid_next='AUTOMATIC';
start slave;
show slave status\G


5、如果没有开启gtid,可以执行跳过这个大事务:

stop slave;
SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;
start slave;
show slave status\G
 

6、如果是5.7及以上可以跳过这对应大事务操作的表,这个是有风险的,可能会造成数据不一致,等主从延时恢复后,需要比较一下主从数据是否一致

stop slave;
CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE = ('ddjct0.ods_zsj_terminal_scan');
start slave;

执行上面步骤后需马上去除过滤操作,尽可能地减少主从不一致的情况发生

stop slave;

CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE = ();

start slave;

相关内容

热门资讯

山海邂逅悦来玥美!青岛银丰玥美... 时光淬炼初心,山海见证成长。三百余日夜匠心耕耘,青岛银丰玥美酒店与崂山为伴,与黄海为邻,融青岛山海风...
摸鱼、钓虾、吃瓜、赏荷…初夏时... 这个周末,一场场充满野趣的“田园嘉年华”在沪郊金山多个农场上演,吸引众多市民带着孩子下乡来,赛跑、吃...
原创 戚... 5月28日,北京环球影城迎来了一对温暖的家庭画面:戚薇和李承铉携三岁半的儿子Seven现身游玩。现场...
滹沱河畔 遇见“诗和远方” 图为市民在滹沱河畔休闲娱乐。 初夏五月,惠风和畅。徜徉在石家庄滹沱河生态区(城区段),澄澈河水蜿蜒...
在迪士尼排队两小时,我才看清V... 文丨沈理 在网上看到一则新闻: 上海迪士尼,创极速光轮排队区。一个父亲牵着七八岁的儿子,已经在烈日...