打開mysql的bin log功能:對于mysql也是支持增量備份,但要打開mysql的bin log功能。我們修改mysql的配置文件。linux是/etc/my.cnf,windows是mysql的安裝目錄/my.ini我們在[mysqld]下面加上log-bin一行代碼,如下面。[mysqld]log-bin=mysql-bin復(fù)制代碼加完后重起mysql即可。某客戶更新數(shù)據(jù)的時(shí)候,誤刪了數(shù)據(jù)庫的內(nèi)容,因?yàn)閿?shù)據(jù)庫做了主從,但是沒有做備份(備份很重要啊!)幸好開啟了bin-log,之后只好把整個(gè)日志的記錄拿回來本地進(jìn)行恢復(fù)。之后自己也做了一個(gè)簡單的測試,對數(shù)據(jù)進(jìn)行恢復(fù),具體如下:
1、新建一個(gè)表CREATE TABLE `lynn`.`sn_test` ( `name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL , `age` INT( 3 ) NOT NULL ) ENGINE = MYISAM;
2、插入多條數(shù)據(jù)INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn1', '1');INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn2', '2'); INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn3', '3'); INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn4', '4');
3、查看數(shù)據(jù)并刪除mysql> select * from sn_test;+-------+-----+| name | age |+---------+---+| lynn1 | 1 || lynn2 | 2 || lynn3 | 3 || lynn4 | 4 |+---------+-----+4 rows in set (0.00 sec)mysql> delete from sn_test;Query OK, 4 rows affected (0.00 sec)mysql> select * from sn_test;Empty set (0.00 sec)4、mysqlbinlog恢復(fù)數(shù)據(jù)mysqlbinlog mysql-bin.000006 > 1.sql查看1.txt里面數(shù)據(jù)插入的紀(jì)錄,把刪除之前的數(shù)據(jù)進(jìn)行恢復(fù)mysqlbinlog mysql-bin.000006 --start-position=2471 --stop-position=2876 | mysql -uroot -p123重新登錄,查看數(shù)據(jù),OK,已經(jīng)成功恢復(fù)了對于數(shù)據(jù)庫操作,應(yīng)該注意如下問題:1、要常備份(全備,增量備份),出了問題可以最快恢復(fù)數(shù)據(jù);2、操作數(shù)據(jù)庫前,要把需要操作的數(shù)據(jù)庫或者表dump出來;3、需要把bin-log打開,就算沒有做上面的兩步,也可以通過日志恢復(fù)數(shù)據(jù)