1.查看数据库是否开启binlog
show variables like '%log_bin%';
状态是ON说明已经开启
开启binlog配置可以参考https://blog.youkuaiyun.com/letterss/article/details/89491552里面的my.cnf配置。
查询当前binlog文件
show master status;
可以看到当前的binlog文件是mysql-bin.000002
2.安装pip和binlog2sql
wget https://bootstrap.pypa.io/get-pip.py
python get-pip.py
pip -V (查看pip是否安装成功)
yum -y install git
git clone https://github.com/danfengcao/binlog2sql.git && cd binlog2sql
pip install -r requirements.txt
安装成功后,进入binlog2sql目录
cd /binlog2sql/binlog2sql
在此目录下执行以下命令查询误删大概时间的sql日志
python binlog2sql.py -h localhost -u root -p admin -d 数据库名 -t 表名 --start-file='mysql-bin.000002' --start-datetime='2019-6-26 14:00:00' --stop-datetime='2019-6-26 14:05:00'
可以看到这个时间我删除了一条数据,位置开始在6678,结束在7028,执行以下命令生成回滚sql,保存在根目录下面
python binlog2sql.py -h127.0.0.1 -P3306 -uroot -padmin -d数据库名 -t表名--start-file='mysql-bin.000002' --start-position=6678 --stop-position=7028 -B > /b.sql
可以看回滚的sql语句了。
如果数据表被drop了,我们只需要把表(包括表结构)重新建立,然后依照上面查询被删除前该表的的日志信息再回滚sql就行了。