恢复slave上的某几张表的方法mysql
摘录自《MySQL管理之道》Page126sql
有时候,slave上只是几张表有些问题,若是从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间,长时间的持锁还容易影响到业务。数据库
下面介绍一种方法,恢复test_DB下的3张表tb一、tb二、tb3,操做以下:bash
一、在slave上先中止复制ide
> stop slave;
二、在主库上导出3张须要恢复的表,并记录下同步的binlog和POS点。spa
# mysqldump -uroot -proot -q --single-trasaction --master-data=2 test_DB tb1 tb2 tb3 > /root/tb123.sql
三、查看/root/tb123.sql 找到记录的binlog和POS点线程
# more /root/tb123.sql 例如 “master_LOG_FILE='mnysql-bin.000010',master_LOG_POS=10020;”
四、作change master to操做:ip
> 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;
五、把/root/tb123.sql复制到slave机器上,并在slave机器上导入/root/tb123.sql同步
# mysql -uroot -proot test_DB < /root/tb123.sql
六、导入完毕,便可开启slave同步。it
> start slave;
操做完成,在slave上执行show slave status\G查看便可。