文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

两个场景下Mysqldump数据库备份恢复

2022-02-08 22:58

关注

两个场景下Mysqldump数据库备份恢复

    昨天凌晨2点做过一次完全备份,白天正常使用,该下班的时候,好巧啊!硬盘坏了。不过幸运的是做过备份并且二进制日志和数据库分开存放

image.png

1、建立数据库并开启二进制日志

image.png

建立用于存放二进制日志的文件夹,修改文件夹属组属主使mysql用户可以读

image.png

二点钟做完全备份,备份完看下是否备份成功

mysqldump -A -F --single-transaction --master-data=2 > /backup/fullbak`date +%F`.sql
 

image.png

less /backup/fullbak2019-07-11.sql    #--master-data选项在备份时自动记录bin-log的位置

image.png

模拟2点到18点的数据修改

image.png

2、存放数据库的硬盘损坏,所有数据库丢失

image.png

3、还原

故障恢复中可以让用户暂停访问数据库

vi /etc/my.cnf  #添加一行

image.png

systemctl restart mariadb

查看当前二进制日志的位置

image.png

从二进制日志中获取2点到18点数据

[root@swh ~]mysqlbinlog  --start-position=245 /data/logbin/mysql-bin.000003 > /backup/inc.sql
[root@swh ~]#mysqlbinlog  /data/logbin/mysql-bin.000004 >> /backup/inc.sql
[root@swh ~]#mysqlbinlog  /data/logbin/mysql-bin.000005 >> /backup/inc.sql
[root@swh ~]#mysqlbinlog  /data/logbin/mysql-bin.000006 >> /backup/inc.sql
 

 

由于恢复数据库会产生大量的日志,可以临时关闭二进制日志

MariaDB [(none)]> set sql_log_bin=off;
MariaDB [(none)]> source  /backup/fullbak2019-07-11.sql  #导入完全备份
MariaDB [(none)]> source  /backup/inc.sql     #导入增量备份
MariaDB [(none)]> set sql_log_bin=on;
恢复后检查数据库,恢复访问
MariaDB [hellodb]> select * from students;
 

image.png

vi /etc/my.cnf  #去掉skip-networking
 

场景二

    凌晨2点做过一次完全备份,白天使用过程中,某同事误删除数据库,当时并未发现,直到下班的时候出故障了

image.png

1、数据库完全备份

mysqldump -A -F --single-transaction --master-data=2 > /backup/fullbak`date +%F`.sql
 

image.png

less /backup/fullbak2019-07-11.sql       #--master-data选项在备份时自动记录bin-log的位置

image.png

2、表被删除,但是没有发现,继续使用,在18点发现问题

image.png

3、还原

故障恢复中可以让用户暂停访问数据库

vi /etc/my.cnf  #添加一行

image.png

systemctl restart mariadb

查看当前日志的位置

image.png

根据备份文件中记录的日志位置,从二进制日志获取增量

[root@swh ~]#mysqlbinlog  --start-position=245 /data/logbin/mysql-bin.000013 > /backup/inc.sql
[root@swh ~]#cp /backup/inc.sql  /backup/inc.sql.bak    #修改下备份下
[root@swh ~]#vi /backup/inc.sql   #从二进制日志中找出删表语句并删除,剩下的日志就是使用的日志
 

image.png

[root@swh ~]#rm -rf /var/lib/mysql/*    #可以选择删除所有数据库恢复,或者直接恢复增量备份
[root@swh ~]#systemctl restart mariadb
MariaDB [(none)]> set sql_log_bin=off;
MariaDB [(none)]> source  /backup/fullbak2019-07-11.sql
MariaDB [(none)]> source /backup/inc.sql
MariaDB [(none)]> set sql_log_bin=on;
 

检查数据

image.png

image.png

vi /etc/my.cnf  #去掉skip-networking
 

虽然可以恢复但是花费的时间成本或许是相当大的,生产环境还需慎重。郑州人流医院:http://jbk.39.net/yiyuanfengcai/tsyl_sysdfkyy/

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯