恢复MySQL slave上的某几张表的方法
2016-06-28 09:41
260 查看
恢复slave上的某几张表的方法
摘录自《MySQL管理之道》Page126
有时候,slave上只是几张表有些问题,如果从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间,长时间的持锁还容易影响到业务。
下面介绍一种方法,恢复test_DB下的3张表tb1、tb2、tb3,操作如下:
1、在slave上先停止复制
2、在主库上导出3张需要恢复的表,并记录下同步的binlog和POS点。
3、查看/root/tb123.sql 找到记录的binlog和POS点
4、把/root/tb123.sql复制到slave机器上,并做change master to操作:
5、在slave机器上导入/root/tb123.sql
6、导入完毕,即可开启slave同步。
摘录自《MySQL管理之道》Page126
有时候,slave上只是几张表有些问题,如果从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间,长时间的持锁还容易影响到业务。
下面介绍一种方法,恢复test_DB下的3张表tb1、tb2、tb3,操作如下:
1、在slave上先停止复制
> stop slave;
2、在主库上导出3张需要恢复的表,并记录下同步的binlog和POS点。
# mysqldump -uroot -proot -q --single-trasaction --master-data=2 test_DB tb1 tb2 tb3 > /root/tb123.sql
3、查看/root/tb123.sql 找到记录的binlog和POS点
# more /root/tb123.sql 例如 “master_LOG_FILE='mnysql-bin.000010',master_LOG_POS=10020;”
4、把/root/tb123.sql复制到slave机器上,并做change master to操作:
> 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、在slave机器上导入/root/tb123.sql
# mysql -uroot -proot test_DB < /root/tb123.sql
6、导入完毕,即可开启slave同步。
> start slave;操作完成,在slave上执行show slave status\G查看即可。
相关文章推荐
- mysql新建表时提示Table 'db.table' doesn't exist解决方法
- mysql 行列转换方式
- [转]MySQL主从复制入门
- mysql常用的增删改操作
- session入mysql
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- mysql xtrabackup 备份恢复实现分享
- MYSQL + MHA +keepalive + VIP安装配置(一)--MYSQL安装配置
- MYSQL + MHA +keepalive + VIP安装配置(二)--MHA的配置
- mysql数据库sql优化原则
- MySQL添加用户、删除用户与授权
- mybatis不能插入,查询中文的问题以及可能的解决办法,以及Mysql数据库编码的设置
- Mysql常用命令
- mysql函数大全
- MySQL按照汉字的拼音排序
- MySql数据导入导出cvs文件命令
- mysql-5.7.9-winx64 绿色版安装以及恢复数据方法
- Mysql命令整理
- MySql 5.7.13 覆盖安装问题
- Mysql数据库AB复制简单实现