iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql, mariadb删库、恢复的完整模拟实现
  • 880
分享到

mysql, mariadb删库、恢复的完整模拟实现

2024-04-02 19:04:59 880人浏览 八月长安
摘要

模拟场景: 周日全备份 -- 周一10:00删库db1,-- 10:10发现某些页面无法访问,如何恢复数据? 注意: 由于库不仅仅一个,因此db1删除,用户可能正常的访问db2,但是多个数据库之间往往是有关

模拟场景:

周日全备份 -- 周一10:00删库db1,-- 10:10发现某些页面无法访问,如何恢复数据?

注意:

由于库不仅仅一个,因此db1删除,用户可能正常的访问db2,但是多个数据库之间往往是有关联的,    
如商品数据库和订单数据库,因此为了避免数据的不一致性,往往会导致逻辑上出现问题的;
此时应当停止服务;即暂停用户的访问,这是一个大的问题,这是需要慎重选择的,是服务重要还是数据
更重要,最好向上级报告。

处理逻辑:

1、停止服务:断开数据库与远程应用之间的网络连接,这样只有本地用户可以管理;
2、逻辑梳理:
全备份恢复:周日的全备份;
周日至周1的10:00间的数据;刨除删除的sql命令;
周一10:00 - 10:10的数据;

如果业务数据不是十分的重要,那么就恢复周日的全备份,丢失全备份至周1 10:00的数据。

[root@Centos7x ~]$Mysqldump -A -F --master-data=2 --single-transaction > all_`date +%F_%T`.sql
[root@centos7x ~]$less all_2018-02-24_21\:46\:13.sql 
-- Position to start replication or point-in-time recovery from
--
-- CHANGE MASTER TO MASTER_LOG_FILE='mariadb-bin.000010', MASTER_LOG_POS=245;
--
-- Current Database: `hellodb`

那么对于测试环境,'mariadb-bin.000010', MASTER_LOG_POS=245之前的二进制日志数据都是可以删除的; 
单机备份时,--master-data=1或者2都是可以的;但是如果是主动复制那么最好是1;

模拟故障:

模拟修改和删除操作;
MariaDB [hellodb]> select * from students;
+-------+---------------+-----+--------+---------+-----------+
| StuID | Name | Age | Gender | ClassID | TeacherID |
+-------+---------------+-----+--------+---------+-----------+
| 1 | Shi Zhongyu | 22 | M | 2 | 3 |
| 2 | Shi Potian | 22 | M | 1 | 7 |
| 3 | Xie Yanke | 53 | M | 2 | 16 |
| 4 | Ding Dian | 32 | M | 4 | 4 |
| 5 | Yu Yutong | 26 | M | 3 | 1 |
| 6 | Shi Qing | 46 | M | 5 | NULL |
| 7 | Xi Ren | 19 | F | 3 | NULL |
| 8 | Lin Daiyu | 17 | F | 7 | NULL |
| 9 | Ren Yingying | 20 | F | 6 | NULL |
| 10 | Yue Lingshan | 19 | F | 3 | NULL |
| 11 | Yuan Chengzhi | 23 | M | 6 | NULL |
| 12 | Wen Qingqing | 19 | F | 1 | NULL |
| 13 | Tian Boguang | 33 | M | 2 | NULL |
| 14 | Lu Wushuang | 17 | F | 3 | NULL |
| 15 | Duan Yu | 19 | M | 4 | NULL |
| 16 | Xu Zhu | 21 | M | 1 | NULL |
| 17 | Lin Chong | 25 | M | 4 | NULL |
| 18 | Hua Rong | 23 | M | 7 | NULL |
| 19 | Xue Baochai | 18 | F | 6 | NULL |
| 20 | Diao Chan | 19 | F | 7 | NULL |
| 21 | Huang Yueying | 22 | F | 6 | NULL |
| 22 | Xiao Qiao | 20 | F | 1 | NULL |
| 23 | Ma Chao | 23 | M | 4 | NULL |
| 24 | Xu Xian | 27 | M | NULL | NULL |
| 25 | Sun Dasheng | 100 | M | NULL | NULL |
+-------+---------------+-----+--------+---------+-----------+
25 rows in set (0.00 sec)

    MariaDB [hellodb]> insert into students (name,age,gender) values('a','29','F');
    Query OK, 1 row affected (0.01 sec)

    MariaDB [hellodb]> select * from students;
    +-------+---------------+-----+--------+---------+-----------+
    | StuID | Name          | Age | Gender | ClassID | TeacherID |
    +-------+---------------+-----+--------+---------+-----------+
    |     1 | Shi Zhongyu   |  22 | M      |       2 |         3 |
    |     2 | Shi Potian    |  22 | M      |       1 |         7 |
    |     3 | Xie Yanke     |  53 | M      |       2 |        16 |
    |     4 | Ding Dian     |  32 | M      |       4 |         4 |
    |     5 | Yu Yutong     |  26 | M      |       3 |         1 |
    |     6 | Shi Qing      |  46 | M      |       5 |      NULL |
    |     7 | Xi Ren        |  19 | F      |       3 |      NULL |
    |     8 | Lin Daiyu     |  17 | F      |       7 |      NULL |
    |     9 | Ren Yingying  |  20 | F      |       6 |      NULL |
    |    10 | Yue Lingshan  |  19 | F      |       3 |      NULL |
    |    11 | Yuan Chengzhi |  23 | M      |       6 |      NULL |
    |    12 | Wen Qingqing  |  19 | F      |       1 |      NULL |
    |    13 | Tian Boguang  |  33 | M      |       2 |      NULL |
    |    14 | Lu Wushuang   |  17 | F      |       3 |      NULL |
    |    15 | Duan Yu       |  19 | M      |       4 |      NULL |
    |    16 | Xu Zhu        |  21 | M      |       1 |      NULL |
    |    17 | Lin Chong     |  25 | M      |       4 |      NULL |
    |    18 | Hua Rong      |  23 | M      |       7 |      NULL |
    |    19 | Xue Baochai   |  18 | F      |       6 |      NULL |
    |    20 | Diao Chan     |  19 | F      |       7 |      NULL |
    |    21 | Huang Yueying |  22 | F      |       6 |      NULL |
    |    22 | Xiao Qiao     |  20 | F      |       1 |      NULL |
    |    23 | Ma Chao       |  23 | M      |       4 |      NULL |
    |    24 | Xu Xian       |  27 | M      |    NULL |      NULL |
    |    25 | Sun Dasheng   | 100 | M      |    NULL |      NULL |
    |    26 | a             |  29 | F      |    NULL |      NULL |
    +-------+---------------+-----+--------+---------+-----------+
    26 rows in set (0.00 sec)

    MariaDB [hellodb]> 

MariaDB [hellodb]> drop database hellodb ;
Query OK, 7 rows affected (0.01 sec)

MariaDB [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| infORMation_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)

MariaDB [(none)]> use test;
Database changed

MariaDB [test]> create table t1(id int);
Query OK, 0 rows affected (0.01 sec)

MariaDB [test]> select * from test;
ERROR 1146 (42S02): Table 'test.test' doesn''t exist
MariaDB [test]>
MariaDB [test]> show tables;
+----------------+
| Tables_in_test |
+----------------+
| t1 |
+----------------+
1 row in set (0.00 sec)

MariaDB [test]> flush tables with read lock;
Query OK, 0 rows affected (0.00 sec)

MariaDB [test]> select * from t1;
Empty set (0.00 sec)

MariaDB [test]> insert t1 values(1);
ERROR 1223 (HY000): Can''t execute the query because you have a conflicting read lock
MariaDB [test]>

数据恢复操作:

MariaDB [test]> show master logs;
+--------------------+-----------+
| Log_name | File_size |
+--------------------+-----------+
| mariadb-bin.000001 | 7700 |
| mariadb-bin.000002 | 290 |
| mariadb-bin.000003 | 290 |
| mariadb-bin.000004 | 290 |
| mariadb-bin.000005 | 290 |
| mariadb-bin.000006 | 290 |
| mariadb-bin.000007 | 290 |
| mariadb-bin.000008 | 290 |
| mariadb-bin.000009 | 290 |
| mariadb-bin.000010 | 669 |
+--------------------+-----------+
10 rows in set (0.00 sec)

刷新日志:
那么'mariadb-bin.000010', MASTER_LOG_POS=245之前的数据使用全备份恢复;
'mariadb-bin.000010', MASTER_LOG_POS=245与'mariadb-bin.000011', MASTER_LOG_POS=245
之间的数据使用二进制日志进行恢复;

MariaDB [test]> flush logs;
Query OK, 0 rows affected (0.01 sec)

MariaDB [test]> show master logs;
+--------------------+-----------+
| Log_name | File_size |
+--------------------+-----------+
| mariadb-bin.000001 | 7700 |
| mariadb-bin.000002 | 290 |
| mariadb-bin.000003 | 290 |
| mariadb-bin.000004 | 290 |
| mariadb-bin.000005 | 290 |
| mariadb-bin.000006 | 290 |
| mariadb-bin.000007 | 290 |
| mariadb-bin.000008 | 290 |
| mariadb-bin.000009 | 290 |
| mariadb-bin.000010 | 714 |
| mariadb-bin.000011 | 245 |
+--------------------+-----------+
11 rows in set (0.01 sec)

如果是全备份后的二进制日志有多个,那么需要都复制出来,并且合并;
[root@centos7x ~]$cp /var/lib/mysql/mariadb-bin.000010 .
[root@centos7x ~]$ls
all_2018-02-24_21:46:13.sql all.sql anaconda-ks.cfg hellodb_InnoDB.sql initial-setup-ks.cfg mariadb-bin.000010

[root@centos7x ~]$mysqlbinlog --start-position=245 mariadb-bin.000010

[root@centos7x ~]$mysqlbinlog --start-position=245 mariadb-bin.000010 > binlog.sql

删除二进制日志中的删除数据库的SQL语句;
[root@centos7x ~]$vim binlog.sql
drop database hellodb

恢复数据之前还需要临时将记录二进制日志的功能暂时关掉;

MariaDB [test]> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin | ON |
+---------------+-------+
1 row in set (0.00 sec)

MariaDB [test]> set sql_log_bin=0;
Query OK, 0 rows affected (0.00 sec)

MariaDB [test]> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin | OFF |
+---------------+-------+
1 row in set (0.00 sec)

sql_log_bin和/etc/my.cnf中的log_bin选项,都是可以影响二进制记录的选项,但是其中一个关闭,那么
二进制日志记录功能就关闭了;其中log_bin在配置文件中,修改的话是需要重启MySQL服务的;
而sql_log_bin是回话级别的,即时生效;

数据库的读锁;
MariaDB [test]> unlock tables ;
Query OK, 0 rows affected (0.01 sec)

恢复全备份:
MariaDB [test]> source all_2018-02-24_21:46:13.sql

MariaDB [(none)]> select * from hellodb.students;

二进制日志恢复:
最后就是记录二进制日志,恢复用户的访问;
MariaDB [(none)]> source binlog.sql
MariaDB [(none)]> select * from hellodb.students;
| 25 | Sun Dasheng | 100 | M | NULL | NULL |
| 26 | a | 29 | F | NULL | NULL |
+-------+---------------+-----+--------+---------+-----------+

MariaDB [test]> set sql_log_bin=1;
Query OK, 0 rows affected (0.00 sec)

MariaDB [test]> show variables like 'sql_log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| sql_log_bin | ON |
+---------------+-------+
1 row in set (0.00 sec)

您可能感兴趣的文档:

--结束END--

本文标题: mysql, mariadb删库、恢复的完整模拟实现

本文链接: https://www.lsjlt.com/news/37291.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL Server数据库的三种恢复模式:简单恢复模式、完整恢复模式和大容量日志恢复模式
    如何图形界面下修改恢复模式 找到你想修改的数据库 右键 > 属性  > 左侧 选项既可看到 1.Simple 简单恢复模式, Simple模式的旧称叫”Checkpoint with...
    99+
    2024-04-02
  • Oracle数据库实现SQL注入模拟与恢复
    本篇内容主要讲解“Oracle数据库实现SQL注入模拟与恢复”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle数据库实现SQL注入模拟与恢复”吧!1.&...
    99+
    2024-04-02
  • 利用MySQL的binlog恢复误删的数据库
    1 查看当前数据库内容并备份数据库 查看数据库信息: 备份数据库: [root@localhost ~]# mysqldump -u root -p t > /mnt/t.sqlEnter pass...
    99+
    2023-09-23
    数据库 mysql sql
  • oracle数据库中怎么实现误删恢复
    oracle数据库中怎么实现误删恢复,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一.如果只是误删部分数据或者某条数据可以通过1、sele...
    99+
    2024-04-02
  • 怎么恢复mysql数据库中删除的数据库
    要恢复已删除的 mysql 数据库,首先确认其已删除。然后,有两种恢复方法:使用备份文件或从二进制日志文件恢复。从备份文件恢复需要先停止服务器、复制文件并运行查询。从二进制日志文件恢复则...
    99+
    2024-04-14
    mysql
  • windows下恢复mysql数据库被删除的解决办法
    目录 项目场景: 解决步骤:  1.命令行进入mysql,执行SHOW MASTER STATUS; 2.将文件移到别的位置 3.恢复 1.命令行输入:mysqlbinlog D:\HASEEZ8-bin.000006 > recovery...
    99+
    2023-09-15
    数据库 mysql windows
  • MySQL之xtrabackup备份恢复的实现
    目录1、安装xtrabackup2、备份2.1、做一次全备2.2、进入mysql添加数据2.3、做一次增备2.4、删除数据库(千万不要在生产库执行!!!)3、恢复3.1、准备阶段3.2、模仿数据库丢失,停掉服务3.3、恢...
    99+
    2023-02-03
    MySQLxtrabackup备份恢复 MySQL备份恢复
  • PHP怎么实现MySQL数据库备份与恢复
    这篇“PHP怎么实现MySQL数据库备份与恢复”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP怎么实现MySQL数据库备...
    99+
    2023-07-06
  • MySQL数据库中怎么实现备份与恢复
    MySQL数据库中怎么实现备份与恢复,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、数据库备份的一些概念1.造成数据丢失的原...
    99+
    2024-04-02
  • 如何利用MySQL的binlog恢复误删数据库详解
    目录1 查看当前数据库内容并备份数据库 2 开启bin_log功能 3 模拟误操作(插入3条数据,删除数据库) 4 数据恢复 5 总结 1 查看当前数据库内容并备份数据库 查看数据...
    99+
    2024-04-02
  • Mysql的Binlog数据恢复:不小心删除数据库详解
    Mysql的Bin log数据恢复:不小心删除数据库 前言:因为不小心删除了测试机器上Mysql的一整个数据库Schema,因为是测试机所以没有做备份,现在通过MySQL的Bin log方式恢复到删除以前的...
    99+
    2024-04-02
  • SpringBoot模拟员工数据库并实现增删改查操作
    目录1:首先创建一个pojo层在里面定义数据2:编写dao层注入数据:3:总结1:首先创建一个pojo层在里面定义数据 Department部门: package com.exa...
    99+
    2024-04-02
  • 通过Docker Compose、Nginx和MariaDB实现PHP应用程序的灾备和恢复
    灾备和恢复是一个重要的话题,对于任何应用程序来说都非常关键。在现代的云计算环境中,使用容器化技术可以轻松实现应用程序的灾备和恢复。本文将介绍如何使用Docker Compose、Nginx和MariaDB来实现PHP应用程序的灾备和恢复,并...
    99+
    2023-10-21
    nginx mariadb Docker Compose:
  • 用 PHP 实现复杂数据结构的完整指南
    php 提供了数组、哈希表、链表、堆栈、队列、树和图等复杂数据结构的完整指南,可用于有效存储和管理不同数据类型和结构,增强 php 程序的性能和效率。 用 PHP 实现复杂数据结构的完...
    99+
    2024-05-07
    php 复杂数据结构 键值对
  • navicat实现mysql备份与恢复的方法
    这篇文章主要介绍navicat实现mysql备份与恢复的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!navicat如何实现mysql备份与恢复推荐:navicat使用教程1、查...
    99+
    2024-04-02
  • Mysql实现增量恢复的方法详解
    实验介绍 增量恢复一般适用的场景: 1、人为的sql语句破坏了数据库 2、在进行下一次完全备份之前发生系统故障导致数据库数据丢失 3、在主从架构中,主库数据发生了故障 丢失完全备份之后更改的数据的恢复步骤 ...
    99+
    2024-04-02
  • binlog2sql如何实现MySQL误操作的恢复
    小编给大家分享一下binlog2sql如何实现MySQL误操作的恢复,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!对于MySQL...
    99+
    2024-04-02
  • PHP实现数据库容器化恢复的方法
    在现代软件开发中,容器化技术已经成为了不可或缺的一部分。 Docker作为其中最流行的容器技术之一,已经被广泛应用于各种类型的应用程序。而对于使用数据库的应用程序而言,如何在容器化环境中保证数据的可靠性和恢复性则是一个非常重要的问题。本文将...
    99+
    2023-05-15
    PHP 恢复 数据库容器化
  • mysql数据库误删除后的数据恢复操作过程是怎样的
    这篇文章给大家介绍mysql数据库误删除后的数据恢复操作过程是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在日常运维工作中,对于mysql数据库的权限的规避,SQL审核优化、数...
    99+
    2024-04-02
  • 使用shell怎么实现一个mysql定时备份、删除、恢复功能
    本篇文章为大家展示了使用shell怎么实现一个mysql定时备份、删除、恢复功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mysql备份脚本:脚本实现:按照数据库名称,全量备份mysql数据库并...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作