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
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值