在日常开发当中,当碰到一些数据被异常修改,排查程序无果情况下,查看MySQL的binlog可能会有意想不到的收获。
一、首先要确定binlog的文件位置,可以通过下面的命令来实现。
show variables like '%datadir%';
执行结果如下图:
二、查看binlog里面的内容
1、查看指定binlog文件内容,可以用下面的命令。
SHOW BINLOG EVENTS IN 'mysql-bin.000020';
执行结果如下图:
2、查看当前正在写入的binlog文件,可以用下面的命令。
SHOW MASTER STATUS
执行结果如下:
3、用mysqlbinlog工具查看
如果需要查询2018-12-18 20:50:00到2018-12-18 21:10:00 数据库为xxx 的操作日志,输入如下命令将数据写入到一个备用的txt即可。
/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=xxx --start-datetime="2018-12-18 20:50:00" --stop-datetime="2018-12-18 21:10:00" /usr/local/mysql/var/mysql-bin.000020 > /tmp/mysqlbinlog.txt
如果是本地查询,输入如下命令
/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=xxx --start-datetime="2018-12-18 20:50:00" --stop-datetime="2018-12-18 21:10:00" /usr/local/mysql/var/mysql-bin.000020 | more
如果需要过滤,可以在后面增加管道命令grep,比例我只要包含insert,update,delete的SQL语句,可以这样写:
/usr/local/mysql/bin/mysqlbinlog --no-defaults --database=xxx --start-datetime="2018-12-18 20:50:00" --stop-datetime="2018-12-18 21:10:00" /usr/local/mysql/var/mysql-bin.000020 |grep update > /tmp/mysqlbinlog.txt