mysql binlog

binlog 日志记录了所有的DDL和DML语句,但不包括查询的语句,语句以事件的方式保存,描述了数据的更改过程,

此日志对发生灾难时数据恢复起到了重要作用。

 

开启mysql binlog

vim my.cnf

basedir = '/home/users/v_liujun03/local/mysql'
datadir = '/home/users/v_liujun03/local/mysql/data'
# port = .....
# server_id = .....
socket = '/home/users/v_liujun03/local/mysql/data/mysqld.sock'
pid-file= '/home/users/v_liujun03/local/mysql/data/mysqld.pid'
log-bin = '/home/users/v_liujun03/local/mysql/data/mysql-bin.log'

log-bin = '/home/users/v_liujun03/local/mysql/data/mysql-bin.log' 给binlog设置一个目录 

expire_logs_day=3 日志保存3天,3天后过期的日志将被自动删除

 

 

 

查看二进制文件

 ../bin/mysqlbinlog mysql-bin.000001

导出

 ../bin/mysqlbinlog mysql-bin.000001  > log.txt

如果要追加 则用'>>'替换'>'

指定位置导出

c:\mysql\bin\>mysqlbinlog --start-position=185 --stop-position=338 e:/log/logbin.000001 > e:/log/log

指定时间导出

c:\mysql\bin\>mysqlbinlog --start-datetime="2010-01-07 11:25:56" --stop-datetime="2010-01-07 13:23:50" e:/log/logbin.000001 > e:/log/log_by_date22.txt 

mysql > flush logs;  重新生成一个日志文件

mysql > reset master; 删除所有二进制日志文件

mysql > PURGE MASTER LOGS TO 'mysql-bin.000002';  将编号为000002之前的所有日志(即msyql-bin.000001)删除

mysql > PURGE MASTER LOGS BEFORE 'yyyy-mm-dd hh:mm:ss';   删除'yyyy-mm-dd hh:mm:ss'之前的所有日志

 

 

恢复

基于时间

基于时间点的恢复,由于误操作,比如说删除了一张表,这时使用上面讲的完全恢复是没有用的,因为日志里面还存在误操作的语句,,我们需要的是恢复到误操作前的状态,然后跳过误操作的语句,再恢复后面操作的语句,假定我们删除了一张表的误操作发生在10:00这个时间点,我们可以使用下面的语句用备份和binlog将数据恢复到故障前

mysqlbinlog --stop-date='2010-09-04 9:59:59' /var/log/mysql-bin.000001 | mysql -uroot -p

 

然后跳过误操作的时间点,继续执行后面的binlog

mysqlbinlog --start-date='2010-09-04 10:01:00' /var/log/mysql-bin.000001 | mysql -uroot -p

其中--stop-date='2010-09-04 9:59:59' 和 --start-date='2010-09-04 10:01:00' 其中的时间是你误操作的时间点,当然了,这个时间点你需要你自己计算的,而且这个时间点还可以涉及到的不只是误操作,还可以有正确的操作也被跳过去了。

基于位置

于上面提到的,使用基于时间点的恢复可能出现,在一个时间点里面可能存在误操作和其他正确的操作,所以我们需要一种更为精确的恢复方式
使用mysqlbinlog查看二进制,可看到

其中drop tables test1这个误操作的end_log_pos为8879917,几下这个id,得出它前后操作的id分别为8879916,8879918
我们将进行位置恢复操作

mysqlbinlog --stop-position='8879916' /var/log/mysql-bin.000001 | mysql -uroot -p

mysqlbinlog --start-position='8879918' /var/log/mysql-bin.000001 | mysql -uroot -p

第一行是恢复到停止位置位置的所以事务,第二性是恢复从给定的起始位置知道二进制日志结束所有事物。

 

参考: 

http://www.jb51.net/article/27919.htm

http://www.blogjava.net/dongbule/archive/2010/09/04/331050.html 

 

posted @ 2015-05-18 15:43  小刘_php  阅读(112)  评论(0)    收藏  举报