MySQL备份方案-->(利用mysqldump以及binlog二进制日志)(二)

2014-11-24 10:33:11 · 作者: · 浏览: 1
gz
日志增量恢复到故障点之前
Shell>/usr/local/myql/bin/mysqlbinlog --stop-date="2010-12-21 10:59:59" mysql-bin.00011|mysql -u root -p 123456
跳过故障的时间点,继续执行后面的binlog,完成恢复
Shell> /usr/local/myql/bin/mysqlbinlog--start-date="2010-12-21 10:59:59" mysql-bin.00011| mysql -u root -p 123456
检查:
用select * from tb等sql命令查看表以及数据是否恢复。
(3) 基于时间点恢复二,当天11点数据故障误操作:
如果上午全备份之后的insert数据被误删除, 在11点发生了误操作.丢失的数据是最后一次备份之前录入的数据,则必须先用全备份文件进行全恢复,然后可以用bin-log日志将数据库恢复到11点之前的那一刻,然后跳过故障时间点11点,再进行恢复下面所有的操作,步骤过程如下:
刷新日志:
Mysql>flush logs;
先从备份文件服务器上copy出来,解压缩,再恢复
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/mysql_20101216_231900.sql.tar.gz /usr/mysqlrestore/
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/ mysql_binlog_20101217_030100.tar.gz /usr/mysqlrestore/
Shell>cd /usr/mysqlrestore/
Shell>tar -xvf mysql_20101216_231900.sql.tar.gz
Shell>tar -xvf mysql_binlog_20101217_030100.tar.gz
恢复最后一次全备份命令:
Shell>/usr/local/mysql/bin/mysql -uroot -p123456 < /tmp/mysqlbackup/mysql_20101216_231900.sql
日志增量恢复到故障点之前
Shell>/usr/local/myql/bin/mysqlbinlog --stop-date="2010-12-21 10:59:59" mysql-bin.00011|mysql -u root -p 123456
跳过故障的时间点,继续执行后面的binlog,完成恢复
Shell> /usr/local/myql/bin/mysqlbinlog--start-date="2010-12-21 10:59:59" mysql-bin.00011| mysql -u root -p 123456
检查:
用select * from tb等sql命令查看表以及数据是否恢复。
(4) 基于时间点恢复三,昨天11点数据故障误操作:
恢复流程,先全恢复,然后日志增量恢复跳过11点后继续日志增量恢复,如下:
先从备份文件服务器上copy出来,解压缩,再恢复
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/mysql_20101216_231900.sql.tar.gz /usr/mysqlrestore/
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/ mysql_binlog_20101217_030100.tar.gz /usr/mysqlrestore/
Shell>cd /usr/mysqlrestore/
Shell>tar -xvf mysql_20101216_231900.sql.tar.gz
Shell>tar -xvf mysql_binlog_20101217_030100.tar.gz
刷新日志:
Mysql>flush logs;
全恢复:
Shell>/usr/local/mysql/bin/mysql -uroot -p123456 < /tmp/mysqlbackup/ mysql_20101216_231900.sql
日志增量恢复到故障点:
Shell>/usr/local/myql/bin/mysqlbinlog --stop-date="2010-12-20 10:59:59" mysql-bin.00010|mysql -u root -p 123456
跳过故障点继续恢复:
Shell>/usr/local/myql/bin/mysqlbinlog --start-date="2010-12-20 10:59:59" mysql-bin.00010mysql-bin.00011| mysql -u root -p 123456
(5) 基于时间点恢复四,多故障点恢复比如2个故障点数据故障误操作:
第一个故障点:2010-12-2113:41:41 –> 2010-12-21 13:42:36
第二个故障点:2010-12-2113:43:16 –> 2010-12-21 13:46:05
恢复流程,先全恢复,然后日志增量恢复跳过第一个故障点后继续日志增量恢复到第二个故障点,然后跳过第二个故障点继续恢复到终点,如下:
先从备份文件服务器上copy出来,解压缩,再恢复
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/mysql_20101216_231900.sql.tar.gz /usr/mysqlrestore/
Shell>/root/s3cmd/s3cmd get s3://csf-backup/mysqldb/ mysql_binlog_20101217_030100.tar.gz /usr/mysqlrestore/
Shell>cd /usr/mysqlrestore/
Shell>tar -xvf mysql_20101216_231900.sql.tar.gz
Shell>tar -xvf mysql_binlog_20101217_030100.tar.gz
刷新日志:
Mysql>flush logs;
全恢复:
Shell>/usr/local/mysql/bin/mysql -uroot -p123456 < /tmp/mysqlbackup/ mysql_20101216_231900.sql
日志增量恢复到第一个故障点之前:
Shell>/usr/local/mysql/bin/mysqlbinlog --stop-date="2010-12-21 13:41:41"mysql-bin.000012| mysql -u root -p123456;
跳过故障点继续恢复到第二个故障点之前:
Shell> /usr/local/mysql/bin/mysqlbinlog--start-date="2010-12-21 13:42:36" --stop-date="2010-12-2113:43:16" mysql-bin.000012 mysql-bin.000013|mysql -u root -p123456;
跳过第二个故障点恢复到flushlogs之时