位置: 编程技术 - 正文

如何恢复MySQL主从数据一致性(mysql怎么恢复数据)

编辑:rootadmin

推荐整理分享如何恢复MySQL主从数据一致性(mysql怎么恢复数据),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql数据恢复,mysql怎么恢复默认设置,恢复mysql数据库,mysql怎么恢复默认设置,mysql怎么恢复默认设置,mysql怎么恢复,mysql恢复初始化,mysql怎么恢复,内容如对您有帮助,希望把文章链接给更多的朋友!

最近被告知,MySQL主从数据库的数据不一致,猜测备库在同步过程中出现了问题,于是,登上备库,使用 mysql> show slave statusG查看,果然,备库在insert语句中因违反主键约束,导致备库停止了同步。现在的问题很明确,就是如何恢复主从库数据的一致性。

可选方案如下:

一、查看Master最新的Position,将其作为Slave复制的起点。

这种思路体现的是过去的不一致既往不咎,现在保持同步即可。看起来,这个思路和恢复主从库数据的一致性的初衷有所违背,但这种方法,简单,高效,在测试环境,对历史数据要求不高的场景中可使用。

二、必须严格的恢复主从库数据的一致性。

在这里,也有两种思路:

1. 备份主库数据,并在从库上恢复,在历史数据一致性的基础上开启同步,但这种方法比较麻烦,必须在主库上执行锁表操作,阻止客户端对于表数据的更新操作,而且在数据量大的情况下,备份也是个耗时的工程。其实,这种方法在实际生产环境中也很少用。

2. Skip掉相关错误

其实,这个说活不是很严谨,准备的说,是跳过相关的事务。在我今天这种情况下,就是skip掉因违反主键约束而失败的insert语句。

如何跳过相关事务

一、停止slave服务

二、SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;

三、开启slave服务。

这里跳过的是一个事务。当然,也可以跳过多个事务,但要谨慎,毕竟,你并不知道跳过的是什么事务。

建议:可反复执行上述步骤,仔细查看导致从库不能同步的语句。有的时候,阻止从库的事务太多,这种方法就显得略为低效。

可分析主库日志的事务,来确定SQL_SLAVE_SKIP_COUNTER的合适值。具体步骤如下:

1、在备库中执行show slave statusG,确认以下两个参数

如何恢复MySQL主从数据一致性(mysql怎么恢复数据)

根据上述两个参数的值,在主库中查看当前阻碍从库复制的事务以及之后的事务。

mysql> SHOW BINLOG EVENTS in 'mysql-bin.' from ;

这个是查看日志文件mysql-bin.中事务ID为后的所有事务。

当然,SHOW BINLOG EVENTS的用法还是相当灵活的,下述方式均可。

mysql> SHOW BINLOG EVENTS in 'mysql-bin.' from G

mysql> SHOW BINLOG EVENTS in 'mysql-bin.' from limit ;

也可在主机环境下通过mysqlbinlog命令查看

如何查询语句的执行情况

在从库跳过相关事务,重新启动Slave后,Slave_IO_Running,Slave_SQL_Running两项均显示“YES”,但Seconds_Behind_Master并没有马上下降,反而缓慢上升。

这时候,通过show processlist语句查看线程的执行情况,发现第一条语句执行时间太长,“State”列显示“Sending data”。关于“Sending data”的含义,官方说明如下:

可见,该语句涉及了大量的磁盘读。

为了进一步分析该语句的耗时分布,可设置profiling变量。步骤如下:

一、在查询开始之前,设置set profiling=on;

二、在语句执行完毕后,通过show profiles查看语句的Query_ID。

三、通过show profile for queryQuery_ID 查看语句的具体执行情况。

最后也发现,该语句在Sending data阶段耗时过久。

总结:

1. 在执行stop slave的时候,stop slave命令被hang住了,在网上查询了相关资料,可能与Slave中有长SQL或Locked的SQL执行有关,在这里,除show processlist外,最好不要执行show slave status以及slave stop等slave相关命令。那么如何解决该问题呢?等待锁定SlaveSQL的线程结束,或者重启数据库。我选择了后者。

2. 在重启备库的过程中,还有段小插曲,在执行start slave命令的时候,报如下错误:ERROR (HY): Slave failed to initialize relay log info structure from the repository。网上很多资料都是推荐重新配置主从集群,这样又回到了开头的方案选择部分了。奇怪的时,我关闭了从库,重新启动,又好了。而两次启动命令唯一的差别就是前一次启动使用的是mysqld,后一次启动使用的是mysqld_safe,而且多带了一个--user参数。

标签: mysql怎么恢复数据

本文链接地址:https://www.jiuchutong.com/biancheng/321304.html 转载请保留说明!

上一篇:MySQL分页优化(mysql大分页优化)

下一篇:解决MySQL Sending data导致查询很慢问题的方法与思路(解决问题)

  • 摊薄净资产收益率是什么意思
  • 代扣代缴增值税是什么意思
  • 发生无偿赠与行为怎么办
  • 电子税务局没有发票开具
  • 以前年度损益调整在借方是什么意思
  • 工程结算是含税还是不含税
  • 个人注册公司有什么优惠政策
  • 公司股东和自然人股东可否代持股权
  • 发票税号错了怎么重开
  • 汇款出国规定
  • 预缴增值税可以在电子税务局操作吗
  • 固定资产累计折旧借贷方向
  • 现金账冲账怎么冲
  • 本月进项大于销项怎么做会计分录
  • 公司发的奖金可以直接公司账户转账给员工吗?
  • 非独立核算的分公司是法人主体吗
  • 不计提税费可以吗
  • 主营业务税金及附加大概比例
  • 跨地区经营建筑企业预缴企业所得税
  • 劳务费个人所得税税率
  • 消费税应纳税额计算方法是什么有何特点
  • 戴尔笔记本电脑哪款性价比最高
  • 电脑上不了网怎么安装网卡驱动
  • 借支单如何做账科目
  • 企业投资的工程项目包括
  • 公司资产报废处理请示
  • Yii2使用驼峰命名的形式访问控制器(实例讲解)
  • 深度deepin系统安装教程
  • php23种设计模式
  • 免抵退应退税额15栏怎么填进去
  • 福利性分配举例
  • wordpress自定义函数
  • uniapp 信息推送
  • 一台电脑能不能接两个键盘
  • 怎么理解php语言
  • php隐藏跳转
  • od输出结构
  • 小规模所得税申报表利润总额是填季报吗
  • 公司与公司往来账表格怎么制作
  • 小规模纳税人无进项票怎么办
  • 专票当天可以领取吗
  • mysql union or
  • 坏账核销的会计处理
  • 公司制作横幅计入什么科目?
  • 个人所得税申报方式选哪个比较好
  • 税控盘的进项税在哪里申报
  • 简易纳税额
  • 现金流量表季度期初现金余额怎么填
  • 普票和专票的区别对比
  • 商业银行提取的盈余公积可用于
  • 企业营改增税率是多少
  • 受托加工的成本
  • 收到社会保险基金结算表
  • 增值税转型不得超过多少
  • 开红字发票如何做分录?
  • 担保属于债权吗
  • 劳务派遣证验资
  • 人工成本包括哪些项目
  • 商业批发企业有哪些
  • window windows10
  • rsync如何同步隐藏文件和排除文件?rsync同步隐藏文件和排除文件的方法
  • 怎么用u盘装xp系统教程
  • vc6_cn_full.exe
  • 电脑进程里的system
  • windows 高分屏
  • 电脑显示器无信号键盘灯不亮
  • Win10怎么打开屏幕键盘
  • 怎么从win8装回win7
  • win8任务栏在底部不显示
  • android内存优化 简书
  • vue3 todo
  • jquery插件ajaxupload实现文件上传操作
  • windowsxp命令行窗口怎么打开
  • 你必须知道的家长六种类型
  • javascript运用
  • Jquery通过ajax请求NodeJS返回json数据实例
  • javascript getattribute
  • jquery写网页
  • 出租车开的发票如何查询校验码?
  • 购房发票的发票代码是哪个
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设