【MySQL 5.7 】从库1032 报错处理
一、简介:
mysql 5.7 多源复制,主从同步的时候,主库update一条数据,从库这条数据已经被删除,导致主从断掉。
Last_Errno: 1032
MySQL主从同步的1032错误,一般是指要更改的数据不存在,SQL_THREAD提取的日志无法应用故报错,造成同步失败
(Update、Delete、Insert一条已经delete的数据)。1032的错误本身对数据一致性没什么影响,影响最大的是造成了同步失败.
二、解决方案:
MySQL5.7.15-log版本,binlog模式为ROW。
show slave status\G,可以看到如下报错:
1 Last_Errno: 1032 2 Last_Error: Coordinator stopped because there were error(s) in the worker(s). The most recent failure being: Worker 3 failed executing transaction '1699 3 7e5e-5707-11e7-a702-94188201787c:161982297' at master log mysql-bin.000309, end_log_pos 774308000. See error log and/or performance_schema.replication_applier_status_by_worker table for more details about this failure or others, if any. Skip_Counter: 0 4 Exec_Master_Log_Pos: 774271552 5 Relay_Log_Space: 1266940262 6 Until_Condition: None 7 Until_Log_File: 8 Until_Log_Pos: 0 9 Master_SSL_Allowed: No 10 Master_SSL_CA_File: 11 Master_SSL_CA_Path: 12 Master_SSL_Cert: 13 Master_SSL_Cipher: 14 Master_SSL_Key: 15 Seconds_Behind_Master: NULL 16 Master_SSL_Verify_Server_Cert: No 17 Last_IO_Errno: 0 18 Last_IO_Error: 19 Last_SQL_Errno: 1032 20 Last_SQL_Error: Coordinator stopped because there were error(s) in the worker(s). The most recent failure being: Worker 3 failed executing transaction '1699 21 7e5e-5707-11e7-a702-94188201787c:161982297' at master log mysql-bin.000309, end_log_pos 774308000. See error log and/or performance_schema.replication_applier_status_by_worker table for more details about this failure or others, if any.
查看 error.log:
vim error.log
2018-10-26T01:55:00.133136+08:00 16179 [ERROR] Slave SQL for channel 'master_6': Worker 3 failed executing transaction '16997e5e-5707-11e7-a702-94188201787c:161982297' at master log mysql-bin.000309, end_log_pos 774308000; Could not execute Update_rows event on table test.test_log; Can't find record in 'test_log', Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the event's master log mysql-bin.000309, end_log_pos 774308000, Error_code: 1032
方法一:跳过错误
1)先跳过这一条错误,让主从同步恢复正常。(或者N条event,一条一条跳过)
set global sql_slave_skip_counter=1;
start slave sql_thread for channel 'master_6';
slave 起来之后,恢复数据,在从库上重新insert 进这条
2)The most recent failure being: Worker 3 failed executing transaction '169921 7e5e-5707-11e7-a702-94188201787c:161982297'
GTID 模式下还可以这样:
set gtid_next='169921 7e5e-5707-11e7-a702-94188201787c:161982297';
begin;
commit;
set gtid_next='automatic';
stop slave sql_thread for channel 'master_6';
start slave sql_thread for channel 'master_6';
方法二:还原被删除的数据
根据错误提示通过mysqlbinglog找到这条数据的sql, 此事件在主服务器Master binlog中的位置是mysql-bin.000309, end_log_pos77430800
1 [root@xxxxx binlog]# mysqlbinlog --no-defaults --stop-position=774308000 mysql-bin.000309 -vv |grep -A 20 774308000 2 #181026 1:55:00 server id 3663306 end_log_pos 774308000 CRC32 0x2969563a Update_rows: table id 52745 flags: STMT_END_F 3 4 BINLOG ' 5 dAPSWxPK5TcAWgAAAIr+Ji4AAAnOAAAAAAEAB21vbml0b3IAEWpvYl9leGVjdXRpb25fbG9nAAsP 6 Dw8PDwMPDwMRERCgAJAB/AP8A8gAUACAPgAAgAbDz1ww 7 dAPSWx/K5TcAFgIAAKAAJy4AAAnOAAAAAAEAAgAL/////4D8JDZlOGJjNGZlLTlmYzktNDllYS1h 8 NjliLWE4YmNjMWZjOGJlZiQAb21zVXBkYXRlV2FyZWhvdXNlT3JkZXJUYXNrU3RhdHVzSm9iZgBv 9 bXNVcGRhdGVXYXJlaG91c2VPcmRlclRhc2tTdGF0dXNKb2JALUAwQC1AUkVBRFlALUAxMC4xNTcu 10 MzIuMzlALUA2NTYyYzQ5YS0zMjQyLTQyNWQtODdhZC1lZTA4N2M0NmYzN2UXAGRwcHZkb2NzZXIx 11 OC5zZXBob3JhLmNuDDEwLjE1Ny4zMi4zOQAAAAAOTk9STUFMX1RSSUdHRVIAAAAAW9IDdID4JDZl 12 OGJjNGZlLTlmYzktNDllYS1hNjliLWE4YmNjMWZjOGJlZiQAb21zVXBkYXRlV2FyZWhvdXNlT3Jk 13 ZXJUYXNrU3RhdHVzSm9iZgBvbXNVcGRhdGVXYXJlaG91c2VPcmRlclRhc2tTdGF0dXNKb2JALUAw 14 QC1AUkVBRFlALUAxMC4xNTcuMzIuMzlALUA2NTYyYzQ5YS0zMjQyLTQyNWQtODdhZC1lZTA4N2M0 15 NmYzN2UXAGRwcHZkb2NzZXIxOC5zZXBob3JhLmNuDDEwLjE1Ny4zMi4zOQAAAAAOTk9STUFMX1RS 16 SUdHRVIBAAAAW9IDdFvSA3Q6Vmkp 17 '/*!*/; 18 ### UPDATE `test`.`test_log` 19 ### WHERE 20 ### @1='6e8bc4fe-9fc9-49ea-a69b-a8bcc1fc8bef' /* VARSTRING(160) meta=160 nullable=0 is_null=0 */ 21 ### @2='omsUpdateWarehouseOrderTaskStatusJob' /* VARSTRING(400) meta=400 nullable=0 is_null=0 */ 22 ### @3='omsUpdateWarehouseOrderTaskStatusJob@-@0@-@READY@-@1@-@6562c49a-3242-425d-87ad-ee087c46f37e' /* VARSTRING(1020) meta=1020 nullable=0 is_null=0 */
事务的语句为: UPDATE `test`.`test_log` where @1=‘’,@2=‘’ (@1为第一个字段,@2为第二个字段)
要是从库少了这个数据,把上面binglog中的update 改为insert
不要记录binlog:
set sql_log_bin=0;
insert into `test`.`test_log` values() ;
set sql_log_bin=1;
start slave sql_thread for channel 'master_6';
posted on 2018-10-26 16:44 狂奔中社会主义酸菜 阅读(2261) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!