无论是误操作还是被黑客攻击,只要有了健全的备份策略,在大的错误都能恢复,下面是我总结的一套无敌备份策略使得在mysql发生错误后能及时不丢失数据的恢复。
备份策略概述:
每日凌晨2:00进行dump对相应数据库进行备份,同时对相应数据库进行binlog日志文件更新。
如果发现数据库错误,只需要先恢复上一个dump的备份,然后再还原当天的binlog日志文件。
举例:
每日12:00执行:
mysqldump database --flush-logs -uroot -p --opt > database_20020601.sql
按照日期规则执行。
如果想恢复到今早10点的数据库,那么:
1、完整备份整个当前数据库
cd /var/lib/mysql
mysqldump -uroot -p123456 sugarcrm > sugarcrm.bak
2、删除当前备份好的数据库
rm -rf sugarcrm
3、先用dump恢复
mysql -uroot -p123456
mysql database -uroot -p123456 < database_20020601.sql
4、再用binlog按时间恢复
mysqlbinlog --stop-date="2011-07-28 10:18:49" /var/lib/mysql/mysql-bin.000006 | mysql -uroot -p123456
备注:
1、最好要把dump备份和binlog备份保存在异地--异地备份!!!
2、mysql主从复制
阅读(1293) | 评论(0) | 转发(0) |