您的位置:首页 > 数据库 > MySQL

mysql 同步出错 快速恢复

2010-02-04 16:55 113 查看
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;

自己的使用体会:方法一是强制性从某一个点开始同步,会有部分没有同步的数据丢失,后续主服务器上删除记录同步也会有一些错误信息,不会影响使用.方法二不一定会有效果.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: