中国网管论坛's Archiver

falin 发表于 2008-5-25 21:44

MySQL完全备份、增量备份与恢复

场景:每周日执行一次完全备份,每天下午1点执行增量备份

[ 适用版本 ] MySQL 4.x - 6.x
[ 配置 ]
执行增量备份的前提条件是MySQL打开log-bin日志开关,例如在my.ini或my.cnf中
加入

log-bin=C:/Program Files/MySQL/MySQL Server 6.0/Data/mysql-bin

“log-bin=”后的字符串为日志记载目录,一般建议放在不同于mysql数据目录的磁盘上。

[ 完全备份]
假定星期日下午1点执行完全备份,适用于MyISAM存储引擎。

mysqldump --lock-all-tables --flush-logs --master-data=2 -u root -p test > backup_sunday_1_PM.sql

对于InnoDB 将--lock-all-tables替换为--single-transaction
--flush-logs 为结束当前日志,生成新日志文件
--master-data=2 选项将会在输出SQL中记录下完全备份后新日志文件的名称,
用于日后恢复时参考,例如输出的备份SQL文件中含有:

-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=106;

其他说明:
如果mysqldump加上--delete-master-logs 则清除以前的日志,以释放空间。但是如果服务器配置为镜像的复制主服务器,用mysqldump --delete-master-logs删掉MySQL二进制日志很危险,因为从服务器可能还没有完全处理该二进制日志的内容。在这种情况下,使用PURGE MASTER LOGS更为安全。

[ 增量备份 ]
每日定时使用 mysqladmin flush-logs来创建新日志,并结束前一日志写入过程。并
把前一日志备份,例如上例中开始保存数据目录下的日志文件 mysql-bin.000002 , ...

[ 从备份中恢复 ]
* 恢复完全备份
mysql -u root -p < backup_sunday_1_PM.sql

* 恢复增量备份
mysqlbinlog mysql-bin.000002 ... | mysql -u root -p

注意此次恢复过程亦会写入日志文件,如果数据量很大,建议先关闭日志功能。

搞坏PC 发表于 2008-5-28 08:01

:@: 这么好的贴子都不来顶一下.看楼主这个说的多明白!

iamshiyu 发表于 2008-6-11 12:53

的确很有用。

manwl654321 发表于 2008-7-4 22:20

:loveliness: 学习了!

rgbing2000 发表于 2008-7-24 18:57

好:lol

tossboy 发表于 2008-8-30 17:06

这个貌似跟SQL不一样啊
backup语句以及一些语句格式都不一样

phi36899 发表于 2008-8-30 19:39

8错,不顶不是Bitscn的坛友

xl1217 发表于 2008-9-8 21:20

先了解下

页: [1]

Powered by Discuz! Archiver 6.1.0  © 1999-2008 bbs.bitsCN.com