mysql基于binlog实现数据备份与恢复(常用操作)

一、mysql binlog数据备份

1、my.ini配置 mysqld

#设置日志前缀
log-bin=mysql-bin
#设置日志保留天数
expire_logs_days=30
#设置日志文件最大大小
max_binlog_size=100M

二、mysql binlog数据恢复

查看是否开启binlog
show variables like 'log_bin';

#查看所有binlog日志
show master logs;

#查看最新binlog
show binlog events;

查看binlog开始时间和结束时间
./mysqlbinlog --base64-output=DECODE-ROWS --verbose mysql-bin.00000x | head -n20 
./mysqlbinlog --base64-output=DECODE-ROWS --verbose mysql-bin.000002 | tail -n20

linux binlog日志转sql日志模式 (方便查看执行sql语句位置)
./mysqlbinlog --no-defaults --base64-output=decode-rows -v 
 --start-datetime="2023-08-09 15:01:00" --stop-datetime="2023-08-12 09:51:53" 
 --database=test  /www/server/data/mysql-bin.000101
 > mysql-bin00100.sql
 
window binlog转sql
mysqlbinlog   F:/data/mysql-bin.000102  > mysql-bin000102.sql	 

binlog文件模糊查询带drop的语句
./mysqlbinlog  --no-defaults --base64-output=decode-rows -v /www/server/data/mysql-bin.000101|grep -i drop


恢复数据
1、按照时间段
./mysqlbinlog --no-defaults --start-datetime="2023-08-01 06:30:57" --stop-datetime="2023-08-05 15:13:59" /www/server/data/mysql-bin.000100 | mysql -u root -p test

2、按照定位
./mysqlbinlog --no-defaults --start-position=4 --stop-position=299 /www/server/data/mysql-bin.000100 | mysql -u root -p123456 test
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL的二进制日志(binlog)记录了对数据库的所有更改操作,包括增删改等操作。如果你误删了某些数据,可以使用binlog来进行恢复。 以下是使用binlog恢复数据的步骤: 1. 确认binlog是否开启,在MySQL配置文件中确认是否有以下配置: ``` [mysqld] log-bin=mysql-bin ``` 如果没有,则需要在配置文件中添加上述配置,并重新启动MySQL服务。 2. 查看binlog日志文件列表 可以使用以下命令查看binlog日志文件列表: ``` mysqlbinlog --no-defaults --base64-output=DECODE-ROWS -v --start-datetime="2022-01-01 00:00:00" --stop-datetime="2022-01-01 23:59:59" mysql-bin.000001 > /tmp/mysql_binlog.sql ``` 上述命令将把2022年1月1日这一天的binlog日志文件转换成文本格式,并保存到/tmp/mysql_binlog.sql文件中。 3. 找到误删的SQL语句 在/binlog.sql文件中查找误删的SQL语句,可以使用grep命令查找。 例如,查找包含“DELETE FROM users WHERE id=100”的SQL语句: ``` grep "DELETE FROM users WHERE id=100" /tmp/mysql_binlog.sql ``` 4. 恢复数据 找到误删的SQL语句后,可以使用mysql客户端连接到数据库,并执行该语句来恢复数据。 例如,执行以下命令来恢复数据: ``` mysql -u root -p mysql> use mydatabase; mysql> DELETE FROM users WHERE id=100; ``` 以上就是使用binlog恢复数据的步骤。需要注意的是,在执行恢复操作前,最好先备份一下数据库,以防止误操作导致数据丢失。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值