天天看点

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

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

摘录自《MySQL管理之道》Page126

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

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

1、在slave上先停止复制

1

<code>&gt; stop slave;</code>

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

<code># mysqldump -uroot -proot -q --single-trasaction --master-data=2 test_DB tb1 tb2 tb3 &gt; /root/tb123.sql</code>

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

<code># more /root/tb123.sql 例如 “master_LOG_FILE='mnysql-bin.000010',master_LOG_POS=10020;”</code>

4、做change master to操作:

2

3

<code>&gt; start slave </code><code>until</code> <code>master_LOG_FILE=</code><code>'mysql-bin.000010'</code><code>,master_LOG_POS=10020;</code>

<code>直到sql_thread线程为NO,这期间的同步报错一律跳过即可,可以用如下命令跳过:</code>

<code>&gt; stop slave; </code><code>set</code> <code>global slave_skip_counter=1; start slave;</code>

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

<code># mysql -uroot -proot test_DB &lt; /root/tb123.sql</code>

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

<code>&gt; start slave;</code>

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

本文转自 lirulei90 51CTO博客,原文链接:http://blog.51cto.com/lee90/1793517,如需转载请自行联系原作者