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

浙公网安备 33010602011771号