mysql主主同步修复

场景:

124为主1:两个slave进程的状态为YES

125为主2:两个slave进程,SQL为NO。

错误方法:

从124备份数据bak.sql,在125进行恢复。这种方法会报主键冲突,如果中途中断或者执行了reset master就会丢数据。

做之前,记得:备份!备份!备份!备份是救命稻草。

正确方法:

1、在124上执行stop slave;reset slave all;

查看file和Position   show master status\G;             

File: mysql-bin.000005
Position: 297506588

备份数据:

mysqldump -u'用户名' -p'密码' --database 库1 库2 > bak.sql

2、确认125上没有应用连接写数据,在125上stop slave;reset slave all;

source bak.sql

CHANGE MASTER TO MASTER_HOST='xx.xx.xx.124',MASTER_USER='用户',MASTER_PASSWORD='密码', MASTER_LOG_FILE='mysql-bin.000005', MASTER_LOG_POS=297506588;

start slave;

3、在125上查看file和Position

File: mysql-bin.000001
Position: 154

4、在124上执行
CHANGE MASTER TO MASTER_HOST='xx.xx.xx.125',MASTER_USER='用户',MASTER_PASSWORD='密码', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154;

start slave;

建议:

使用xtrabackup或者mysqlbackup物理备份恢复的方式恢复主从,这样不容易出错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MySQL同步异常是指在从复制过程中出现的错误或异常,可能导致从数据不一致或同步延迟。对于这种情况,通常可以采取一些措施来解决或修复。 首先,我们可以通过检查MySQL从配置文件、网络连接、用户权限等方面,排查配置问题和网络问题。确保从服务器之间网络连接正常,从配置正确,且用户权限设置正确。 其次,我们可以尝试重启MySQL服务来恢复同步。通过在服务器上执行"FLUSH TABLES WITH READ LOCK"命令,锁定表并停止写入操作,然后重启服务器和从服务器。这可以帮助重新建立同步关系。 如果以上方法未能解决同步异常问题,我们可以考虑使用一些专门用于修复MySQL同步问题的软件工具。例如,Percona Toolkit提供了一些工具,如pt-table-checksum和pt-table-sync,可以用于检查从数据的一致性并修复不一致的数据。这些工具可以帮助找出数据不一致的表和行,并进行同步修复。 此外,如果同步异常是由于网络故障或服务器宕机等硬件故障引起的,我们可以考虑恢复数据库备份来修复同步异常。通过使用备份数据重新构建从复制关系,可以确保数据的一致性,并尽量减小同步延迟。 总而言之,针对MySQL同步异常,我们可以通过检查配置、重启服务、使用专门工具、恢复备份等方式来解决或修复。不同的情况可能需要采取不同的策略,具体方法取决于问题的原因和具体环境。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七七powerful

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值