二进制日志的文件的作用
mysql二进制日志文件用来记录所有用户对数据库操作,即记录用户对数据库操作的sql语句。如果有此文件,当数据库发生意外时,可以通过此文件查看到用户在此文件记录的时间段内用户所做的操作,再和数据库备份配合使用,即可再现用户操作,使数据库恢复。
二进制日志文件的弊端
二进制日志文件开启后,所有对数据库操作的记录均会被记录到此文件,
所以,当长时间开启之后,日志文件会变得很大,占用磁盘空间。
使用二进制日志文件恢复数据库
开启日志文件
mysql默认是不开启日志文件的功能的,需要我们手动开启。操作如下:
1、 打开mysql安装目录/my.ini(windows系统是my.ini文件,linux是my.cnf文件)。
2、 找到[mysqld]这个标签,在此标签下面一行,添加语句:log-bin=binary-log。上面语句中,log-bin说明要开启二进制日志文件,binary-log是二进制日志文件的名字。
(测试的时候我设置的:log-bin=d:/mysql_log/logbin_ouyang.log)
3、 重启mysql服务。可以在mysql安装目录/data 文件夹下看到“binary-log.数字编号”文件,
如binary-log.000001。以后每重启一次mysql服务,都会重新生成二进制日志文件,
文件名中的数字编号依次递增。
(你的上一步给出的文件名,加了个序号 还有一个总的文件 index文件 如图1:)
恢复数据库
使用日志文件恢复数据库必须要有一个数据库备份(只要是在二进制日志文件功能开启之后备份的就行)。恢复数据库时,可以通过时间恢复,也可以通过操作点恢复。
1、通过时间恢复方法如下:
如果我在2011-04-02 00:00:00时刻开启了二进制日志文件功能,并备份了数据库文件。且在2011-04-02 12:00:00数据库发生异常,需要恢复到2011-04-02 10:00:00。则操作如下:
l 用备份将数据库回复到2011-04-02 00:00:00时候的状态。
l 在命令行输入如下命令:
mysqlbinlog --stop-date="你想要恢复的时间" 日志文件的目录/binary-log.000001 | mysql -u root –p(D:/mysql_log>mysqlbinlog logbin_ouyang.000007 --stop-date="2011-10-23 15:05:00"|mysql -uroot -proot) |
这样,系统会自动执行从二进制日志有记录开始截止到2011-04-02 10:00:00,用户所做过的所有操作。与stop-date对应的,还有start-date属性,可以设定执行记录的开始时间。也可以两个属性都设置。
2、通过操作点恢复方法如下:
新闻热点
疑难解答