前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >恢复MySQL slave上的某几张表的方法

恢复MySQL slave上的某几张表的方法

作者头像
保持热爱奔赴山海
发布2019-09-18 11:11:38
9910
发布2019-09-18 11:11:38
举报
文章被收录于专栏:饮水机管理员饮水机管理员

恢复slave上的某几张表的方法

摘录自《MySQL管理之道》Page126

有时候,slave上只是几张表有些问题,如果从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间,长时间的持锁还容易影响到业务。

下面介绍一种方法,恢复test_DB下的3张表tb1、tb2、tb3,操作如下:

1、在slave上先停止复制

代码语言:javascript
复制
> stop slave;

2、在主库上导出3张需要恢复的表,并记录下同步的binlog和POS点。

代码语言:javascript
复制
# mysqldump -uroot -proot -q --single-trasaction --master-data=2 test_DB tb1 tb2 tb3 > /root/tb123.sql

3、查看/root/tb123.sql 找到记录的binlog和POS点

代码语言:javascript
复制
# more /root/tb123.sql 例如 “master_LOG_FILE='mnysql-bin.000010',master_LOG_POS=10020;”

4、做change master to操作:

代码语言:javascript
复制
> start slave until master_LOG_FILE='mysql-bin.000010',master_LOG_POS=10020;
直到sql_thread线程为NO,这期间的同步报错一律跳过即可,可以用如下命令跳过:
> stop slave; set global slave_skip_counter=1; start slave;

5、把/root/tb123.sql复制到slave机器上,并在slave机器上导入/root/tb123.sql

代码语言:javascript
复制
# mysql -uroot -proot test_DB < /root/tb123.sql

6、导入完毕,即可开启slave同步。

代码语言:javascript
复制
> start slave;

操作完成,在slave上执行show slave status\G查看即可。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-06-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档