Crazy knowledge base

mysql 同步出错 快速恢复

1. 把Master机器上的mysql日志保存为txt文件:/usr/local/mysql/bin/mysqlbinlog  ./mysql-bin.000011 >2.txt

查找某个节点:

# at 2270
#100204 16:30:27 server id 1  end_log_pos 2297  Xid = 58
COMMIT/*!*/;
2.在slave操作:

stop slave;

change master to master_host=’192.168.1.71′, master_user=’admin’,master_password=’admin’,master_port=3306,master_log_file=’mysql-bin.000011′,master_log_pos=2270;

start slave;

show slave status;

3.Ok恢复成功

详细恢复:

Master:

再master执行FLUSH TABLES WITH READ LOCK;让master不更新,并且刷新所有的表
然后纪录SHOW MASTER STATUS

000013,   3099714

然后tar cvf data.tar ./data

unlock tables;

Slave:

stop slave;

解压:tar xvf ./data.tar ./data

修改:change master to master_host=’192.168.1.71′, master_user=’root’,master_password=’admin’,master_port=3306,master_log_file=’mysql-bin.000013′,master_log_pos=3099714;

start slave;

重启mysql服务:service mysqld restart

show slave status;

今天在测试新的搜索技术时,检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态:
mysql> show slave status\G
Slave_IO_Running: Yes
Slave_SQL_Running: No
Last_Errno: 1062
….
Seconds_Behind_Master:NULL
原因:
1.程序可能在slave上进行了写操作
2.也可能是slave机器重起后,事务回滚造成的.

解决办法I:
1.首先停掉Slave服务:slave stop

2.到主服务器上查看主机状态:
记录File和Position对应的值。
mysql> show master status;
+——————+———–+————–+——————+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———–+————–+——————+
| mysql-bin.000020 | 135617781 | | |
+——————+———–+————–+——————+
1 row in set (0.00 sec)

3.到slave服务器上执行手动同步:
mysql> change master to
> master_host=’master_ip’,
> master_user=’user’,
> master_password=’pwd’,
> master_port=3307,
> master_log_file=’mysql-bin.000020′,
> master_log_pos=135617781;
1 row in set (0.00 sec)
mysql> slave start;
1 row in set (0.00 sec)
再次查看slave状态发现:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

Seconds_Behind_Master: 0

解决办法II:
mysql> slave stop;
mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
mysql> slave start;

自己的使用体会:方法一是强制性从某一个点开始同步,会有部分没有同步的数据丢失,后续主服务器上删除记录同步也会有一些错误信息,不会影响使用.方法二不一定会有效果.

引用自:http://blog.csdn.net/wujian6636/archive/2010/02/04/5289011.aspx

mysql 同步出错 快速恢复
滚动到顶部