mysql备份还原

1.MySql备份

1.1备份mysql的脚本
在/usr/local/mysql/back/目录下创建备份脚本

#shell
export mysqldump_date=$(date +%Y%m%d_%H%M%S) &&
mysqldump --single-transaction -uroot -paiw123$%^ -A > /usr/local/mysql/back/$mysqldump_date.sql &&
gzip /usr/local/mysql/back/$mysqldump_date.sql
find /usr/local/mysql/back/ -name "*.sql" -mtime +30 -exec rm -f {} ;

-A代表所有数据库,也可以替换为database_name
export 在系统中自定义了个变量mysqldump_date,给备份和压缩命令使用
gzip 为压缩命令,默认压缩了之后会把源文件删除,压缩成.gz文件
find … 这行命令的意思为,查询/usr/local/mysql/back目录下,创建时间30天之前(-mtime +30),文件名后缀为.sql的所有文件 执行删除命令-exec rm -f {} ;。总的意思就是:mysql的备份文件只保留30天之内的,30天之前的都删除掉。

1.2定时任务执行脚本 crontab
执行crontab -e命令修改成如下:

#每隔5分钟执行一次
0 /5 * * * ?  sh /usr/local/mysql/back/mysqldump.sh

数据恢复

mysql -uroot -p123456 shouma-sys < /usr/local/mysql/back/20211229_151645.sql

2.登录mysql查看是否开启了binlog

mysql -uroot -p123456

在这里插入图片描述
若为OFF,则需要开启bin-log,在/etc/my.cnf中增加如下配置:

[mysqld]
log-bin = /usr/local/mysql/back/logs/mysql-bin.log #日志目录
expire-logs-days = 14 #间隔天
max-binlog-size = 500M
server-id = 1
binlog_rows_query_log_events=ON #开启原始Sql

重启mysql,service mysqld restart。

登录mysql,查看binlog日志

show binary logs; 

在这里插入图片描述

查看当前正在写入的binlog

show master status;

在这里插入图片描述
查看binlog的内容

show binlog events in 'mysql-bin.000171';

在这里插入图片描述
刷新binlog

flush logs;

进入到binlog目录,查看binlog

cd /usr/local/mysql/back
mysqlbinlog --start-datetime='2021-12-29 11:00:00' --stop-datetime='2021-12-29 11:10:00 -d lilishop /usr/local/mysql/logs/mysql-bin.000173 > drop.txt

根据binlog信息,分析找到破坏数据的pos点,例如删除
在这里插入图片描述

3. 恢复数据:

若发生异常的时间点为图中点,则我们可以使用备份2和异常点中的binlog合并备份2的数据作为完整数据。
请添加图片描述
第一步:首先恢复最近的一个备份点数据:
第二步:恢复备份点到破坏点期间的binlog数据:

 `mysqlbinlog [options] file | mysql -uroot -proot_password database_name`

–start-datetime 开始时间,格式 2020-06-19 18:00:00
–stop-datetime 结束时间,格式同上
–start-positon 开始位置,(需要查看binlog文件)
–stop-position 结束位置,同上

mysqlbinlog --start-datetime='2021-12-29 15:16:00' --stop-datetime='2021-12-29 15:20:20' /usr/local/mysql/logs/mysql-bin.000176 | mysql -uroot -paiw123$%^ shouma-sys;

若发生异常的时间点为图中点,则我们可以使用备份2和异常点中的binlog合并备份2的数据作为完整数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值