1、查看更新备份时的数据
mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
+------+
2、因为我的存储引擎是Myisam ,为了保证数据的一直我加了参数innodb引擎加参数-F 表示生成新的日志文件
# /usr/local/mysql/bin/mysqldump -uroot -p123456 -l -F data1 > data1.sql
3、备份后,对数据更新
mysql> insert into t1 values(4),(5),(6),(7);
mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
| 6 |
| 7 |
+------+
4、
数据恢复时禁止binlog日志
# /usr/local/mysql/bin/mysql -uroot -p123456 -e "set global sql_log_bin=0"
# /usr/local/mysql/bin/mysql -uroot -p123456 -e "show global variables like 'sql_log_bin'\G"
*************************** 1. row ***************************
Variable_name: sql_log_bin
Value: OFF
5、
# /usr/local/mysql/bin/mysql -uroot -p123456 data1 < data1.sql
mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
+------+
6、
用mysqlbinglog恢复自mysqldump备份以来的binglog日志(不一定只有一个binlog日志)
/usr/local/mysql/bin/mysqlbinlog binlog.000028|/usr/local/mysql/bin/mysql -uroot -p123456 data1
mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
| 6 |
| 7 |
+------+
7 rows in set (0.00 sec)
7、开启binglog日志功能
# /usr/local/mysql/bin/mysql -uroot -p123456 -e "set global sql_log_bin=1"
# /usr/local/mysql/bin/mysql -uroot -p123456 -e "show global variables like 'sql_log_bin'\G"
*************************** 1. row ***************************
Variable_name: sql_log_bin
Value: ON
备份情况举例说明:
周一(2010.11.15)凌晨5点进行了数据库的全备,文件名为:all_bak.sql。全备文件中记录的日志位置是:MASTER_LOG_FILE='mysql-bin.000023', MASTER_LOG_POS=364; 自全备以来产生了3个新的日志文件,分别为mysql-bin.000024,mysql-bin.000025,mysql-bin.000026。其中三个增量日志的最后写入时间分别是上午10点,下午2点与下午6点。
5.1 恢复到某一时间点(可以结合开始位置,结束时间的方式)。
晚上发现中午12点10分左右由于问题使得12点10分以后的数据错乱,需要恢复之前数据。全备文件与增量备份文件完整。
(1)故障停机后,全备数据库
(2)恢复全备文件
mysql -uroot -proot test1<all_bak.sql
(3)恢复全备以来的增量日志文件到12点10分结束
mysqlbinlog --no-defaults mysql-bin.000023 mysql-bin.000024
mysql-bin.000025 --start-position=364 --stop-datetime='2010-11-15
12:10:00' |mysql -uroot -proot
(4)抽查数据,开服务测试
5.2 跳过某一破坏性语句的恢复
晚上时发现下午有误删除了数据库中的一些数据,知道删除的命令和大概时间(下午4点左右),此时需要恢复出误删除的那部分数据。
(1)故障停机后,全备数据库
(2)恢复全备文件
mysql -uroot -proot test1<all_bak.sql
(3)依删除命令和大概时间在mysql-bin.000026中找出删除命令的开始和结束位置号。例如:6678 与6691
(4)恢复增量日志到删除命令开始的位置号。
mysqlbinlog --no-defaults mysql-bin.000023 mysql-bin.000024
mysql-bin.000025 mysql-bin.000026 --start-position=364
--stop-position=6678 |mysql -uroot -proot
(5)从删除命令的结束位置号开始恢复剩余的数据。
mysqlbinlog --no-defaults mysql-bin.000026 --start-position=6691|mysql -uroot -proot
(6)抽查数据,开服务测试
5.3 基于某个数据库的增量恢复
在同一台服务器上运行了多个数据库,可以分开全备数据库,但是增量日志是统一写在一起。所以当单个数据库故障时会对单个数据库进行恢复操作,而其他的数据库不允许停机。
(1)停止故障数据库对应服务,全备数据库
(2)恢复全备文件
mysql -uroot -proot test1<all_bak.sql
(3)恢复故障数据库对应的增量日志部分。
mysqlbinlog --no-defaults mysql-bin.000023 mysql-bin.000024
mysql-bin.000025 mysql-bin.000026 --start-position=364 --database=test1
|mysql -uroot -proot
6
备份数据恢复测试
定期对备份数据进行恢复测试,以抽查验证数据有效性。