MySQL 数据恢复方法(一)

简介: MySQL 数据库故障及误操作恢复方法

数据库故障,需要恢复新实例

使用场景

主数据库故障,无法恢复,且没有容灾及高可用。需要通过备份文件进行恢复。

所需资源

  1. 数据库备份文件
  2. 备份点-故障点之间的binlog文件
  3. 机器资源

操作说明

mysqldump备份文件恢复

  1. 拷贝备份文件到目标机器
  2. 登录新建的目标数据库实例

    1. /opt/alisql/bin/mysql -uroot -p
      Enter password:
      Welcome to the MySQL monitor.  Commands end with ; or \g.
      Your MySQL connection id is 18
      Server version: 5.6.32-log Source distribution
      
      Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.
      
      Oracle is a registered trademark of Oracle Corporation and/or its
      affiliates. Other names may be trademarks of their respective
      owners.
      
      Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
      

3. 使用source命令导入备份文件 $mysqldump.sql
   1.     ```
root@(none) 01:57:16>source mysqldump.sql;

xtrabackup备份文件恢复(仅供全量备份参考)

  1. 拷贝备份文件到目标机器
  2. innobackupex prepare

  3. --apply-log --defaults-file=$my.cnf --use-memory=2048M $backupdir

3. innobackupex restore
   1.     ```
innobackupex --copy-back --defaults-file=$my.cnf --use-memory=2048M $backupdir (必须清空mysqldata目录)
  1. 修改文件权限

  2. -R mysql:mysql $mysqldata

5. 启动新的数据库实例
   1.     ```
cd $mysql_bin_dir; ./bin/mysqld_safe --defaults-file=$my.cnf &

数据误操作(INSERT、DELETE、UPDATE)

使用场景

数据被错误变更,需要恢复记录到正确状态

所需资源

  1. 可以连接目标数据库的机器
  2. binlog日志
  3. binlog2sql工具

操作说明

  1. 环境准备

    1. 部署binlog2sql工具
    2. 调试目标数据库连接
  2. 明确最初误操作开始的binlog文件名$first_binlog_file
  3. 使用binlog2sql工具生成rollback SQL

  4. binlog2sql/binlog2sql.py --flashback -h$db_host -P3306 -u$user -p'$pass' -d$database --start-file='$first_binlog_file' > /tmp/rollback.sql

4. 对rollback SQL进行审核整理
5. 登录数据库进行rollback操作
   1.     ```
root@(none) 01:57:16>source rollback.sql;
  1. 验证数据

数据库误操作(DROP TABLE)

使用场景

数据整张表被误删除,需要恢复到正确状态

所需资源

  1. 被误删除表的数据库$dst_db
  2. 数据库备份文件(误删除之前)
  3. 备份点-误操作之间的binlog文件
  4. 可以连接目标数据库的机器
  5. 恢复用机器资源$backup_host
  6. binlog2sql工具

操作说明

  1. 在$backup_host上使用备份文件恢复数据库,参照第一部分《数据库故障,需要恢复新实例》
  2. 在$dst_db数据库上,使用binlog2sql工具生成误删除表有关的SQL(备份点-误删除点之间的操作记录)

  3. binlog2sql/binlog2sql.py --flashback -h$db_host -P3306 -u$user -p'$pass' -d$database -t$误删除的表名 --start-file='$备份点所在的binlog文件' > /tmp/execute.sql

3. 登录到$backup_host数据库,进行恢复execute.sql数据操作
   1.     ```
root@(none) 01:57:16>source execute.sql;
  1. 在$backup_host上使用mysqldump备份被误删除的表

  2. -h$backup_host -u $user -p $pass $table > $table.sql

5. 登录到$dst_db数据库,将mysqldump出的文件数据导入到目标数据库
   1.     ```
root@(none) 01:57:16>source $table.sql;
  1. 验证数据
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
3月前
|
SQL 监控 关系型数据库
MySQL数据恢复:当灾难发生时如何应对
本文全面解析MySQL数据恢复方案,涵盖误操作、硬件故障、崩溃及灾难场景下的恢复技巧,助你构建可靠的数据安全保障体系。
|
6月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
1126 1
|
3月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
9月前
|
SQL 存储 关系型数据库
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库中进行日期比较的多种方法介绍。
以上方法提供了灵活多样地处理和对比MySQL数据库中存储地不同格式地日子信息方式。根据实际需求选择适当方式能够有效执行所需操作并保证性能优化。
486 10
|
5月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
291 11
|
7月前
|
SQL 数据采集 关系型数据库
实现MySQL与SQL Server之间数据迁移的有效方法
总的来说,从MySQL到SQL Server的数据迁移是一个涉及到很多步骤的过程,可能会遇到各种问题和挑战。但只要精心规划、仔细执行,这个任务是完全可以完成的。
566 18
|
8月前
|
SQL 关系型数据库 MySQL
【MySQL】SQL分析的几种方法
以上就是SQL分析的几种方法。需要注意的是,这些方法并不是孤立的,而是相互关联的。在实际的SQL分析中,我们通常需要结合使用这些方法,才能找出最佳的优化策略。同时,SQL分析也需要对数据库管理系统,数据,业务需求有深入的理解,这需要时间和经验的积累。
304 12
|
6月前
|
关系型数据库 MySQL
MySQL字符串拼接方法全解析
本文介绍了四种常用的字符串处理函数及其用法。方法一:CONCAT,用于基础拼接,参数含NULL时返回NULL;方法二:CONCAT_WS,带分隔符拼接,自动忽略NULL值;方法三:GROUP_CONCAT,适用于分组拼接,支持去重、排序和自定义分隔符;方法四:算术运算符拼接,仅适用于数值类型,字符串会尝试转为数值处理。通过示例展示了各函数的特点与应用场景。
|
8月前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。

推荐镜像

更多