两个场景下Mysqldump数据库备份恢复
admin
2023-04-16 16:22:02
0

场景一

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

3、还原

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

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

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

systemctl restart mariadb

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

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

从二进制日志中获取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;

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

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

场景二

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

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

1、数据库完全备份

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

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

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

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

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

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

3、还原

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

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

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

systemctl restart mariadb

查看当前日志的位置

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

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

[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   #从二进制日志中找出删表语句并删除,剩下的日志就是使用的日志

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

[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;

检查数据

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

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

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

虽然可以恢复但是花费的时间成本或许是相当大的,生产环境还需慎重

相关内容

热门资讯

凤凰连线:中美新一轮经贸磋商,... 中美双方将在韩国举行第七轮经贸磋商。美方的阵容和日程安排如何?在这轮磋商中有哪些关切?凤凰卫视驻韩国...
知情人士:阿联酋秘密打击伊朗,... 据参考消息援引美国《华尔街日报》网站5月11日报道,多名知情人士透露,阿联酋已对伊朗发动军事打击,令...
美防长称美伊停火协议依然有效 △赫格塞思(资料图)当地时间5月12日,美国国防部长赫格塞思表示,他们针对伊朗问题的所有情况都制定了...
特朗普二度来华,五大博弈看点,... 就在5月11日,外交部官宣了一则重磅消息:应中国邀请,美国总统特朗普将于5月13日至15日开启访华行...
科学家预测:“哥斯拉级”厄尔尼... 科学家近日发出警告,太平洋上空正在形成一种被称为“哥斯拉”级的罕见厄尔尼诺气候模式。有科学家预测,这...
200亿美金估值的可灵,值母公... 文 | 影子备忘录 要说今年科技圈最火的赛道,AI短剧绝对排得上号。一部AI仿真人短剧,3人团队、...
多名中国公民在越南乘机遗失财物... 近日,多名中国公民反映在越乘机过程中财物遗失,中国驻胡志明市总领馆提醒中国公民注意:一、强化防范意识...
电视机尺寸一览表70寸长宽 电视机尺寸一览表70寸长宽:一般液晶电视显示屏都是16比9,70寸就是说客它对角线长70寸是106....
东莞一社区推出生育奖励方案,二... 极目新闻记者 柳之萌近日,广东东莞万江街道谷涌社区出台生育奖励方案,对符合条件的二孩家庭一次性奖励1...
80寸液晶电视尺寸长宽多少厘米 80寸液晶电视尺寸长宽多少厘米:80寸的液晶电视大概为181x111厘米,即长度大概在181厘米,宽...