MySQL自动备份与覆盖恢复实战指南

 更新时间:2026年03月11日 09:12:32   作者:波哦波  
本文详细描述了如何使用SQL备份文件恢复MySQL数据库的过程,包括查询当前数据库的字符集和排序规则、创建恢复前备份目录、备份现有数据库、删除旧库、重建新库、使用备份文件覆盖恢复、以及恢复后的检查和测试,需要的朋友可以参考下

一、此前每日备份的脚本

#!/bin/bash

# === 配置部分 ===
BACKUP_BASE_DIR="/data/backup_mysql"
DATE=$(date +%F)
LOG_FILE="${BACKUP_BASE_DIR}/logs/backup-${DATE}.log"
LOCK_FILE="/tmp/mysql_backup.lock"

# 备份选项(1=启用,0=禁用)
ENABLE_FULL_BACKUP=1
ENABLE_PER_DB_BACKUP=1

# === 日志重定向 ===
mkdir -p "${BACKUP_BASE_DIR}/logs"
exec >> "$LOG_FILE" 2>&1

echo "===== MySQL Backup Started: $(date) ====="

# === 加锁,避免重复执行 ===
exec 9>"$LOCK_FILE"
if ! flock -n 9; then
  echo "❗️ 另一个备份任务正在运行,退出..."
  exit 1
fi

# === 全量备份 ===
if [ "$ENABLE_FULL_BACKUP" -eq 1 ]; then
  echo "📦 开始全库备份..."
  FULL_BACKUP_FILE="${BACKUP_BASE_DIR}/all/all-databases-${DATE}.sql"
  FULL_GZ_FILE="${FULL_BACKUP_FILE}.gz"
  mkdir -p "${BACKUP_BASE_DIR}/all"

  mysqldump --all-databases --single-transaction --quick --lock-tables=false > "$FULL_BACKUP_FILE"

  if [ $? -eq 0 ]; then
    echo "✔ 全库备份成功: $FULL_BACKUP_FILE"
    gzip "$FULL_BACKUP_FILE"
    if [ $? -eq 0 ]; then
      echo "✔ 全库压缩成功: $FULL_GZ_FILE"
    else
      echo "✘ 全库压缩失败: $FULL_BACKUP_FILE" >&2
    fi
  else
    echo "✘ 全库备份失败" >&2
    rm -f "$FULL_BACKUP_FILE"
  fi
fi

# === 每库备份 ===
if [ "$ENABLE_PER_DB_BACKUP" -eq 1 ]; then
  echo "📂 开始库级别备份..."
  databases=$(mysql -e "SHOW DATABASES;" | grep -Ev "^(Database|information_schema|performance_schema|mysql|sys)$")

  for db in $databases; do
    echo "🔄 正在备份: $db"
    DB_BACKUP_DIR="${BACKUP_BASE_DIR}/${db}"
    mkdir -p "$DB_BACKUP_DIR"
    DB_BACKUP_FILE="${DB_BACKUP_DIR}/${db}-${DATE}.sql"
    DB_GZ_FILE="${DB_BACKUP_FILE}.gz"

    mysqldump --single-transaction --quick --lock-tables=false "$db" > "$DB_BACKUP_FILE"

    if [ $? -eq 0 ]; then
      echo "✔ 备份成功: $DB_BACKUP_FILE"
      gzip "$DB_BACKUP_FILE"
      if [ $? -eq 0 ]; then
        echo "✔ 压缩成功: $DB_GZ_FILE"
      else
        echo "✘ 压缩失败: $DB_BACKUP_FILE" >&2
      fi
    else
      echo "✘ 备份失败: $db" >&2
      rm -f "$DB_BACKUP_FILE"
    fi
  done
fi

# === 清理过期文件(.sql / .sql.gz) ===
echo "🧹 清理 7 天前的备份文件..."
find "$BACKUP_BASE_DIR" -type f \( -name "*.sql" -o -name "*.sql.gz" \) -mtime +7 -exec rm -f {} \;

echo "===== MySQL Backup Completed: $(date) ====="

二、环境信息

  • 服务器主机名:
  • 服务器 IP:
  • 数据库类型:MySQL
  • MySQL 版本:8.0.42 Community Server
  • 目标数据库:imip_ecb
  • 数据库字符集:utf8mb4
  • 排序规则:utf8mb4_general_ci
  • 备份文件路径(恢复来源):
  • /data/backup_mysql/imip_ecb/imip_ecb-2025-12-11.sql.gz
  • 恢复前保护性备份路径:
    /data/backup_mysql/manual_before_restore/imip_ecb-before-restore-2025-12-11.sql
  • 恢复类型:覆盖源库恢复(在同一实例上,用备份覆盖原有 imip_ecb 库)

三、实际恢复操作步骤

1. 查询imip_ecb数据库字符集与排序规则

mysql -u root -p -e "
SELECT SCHEMA_NAME, DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME
FROM information_schema.SCHEMATA
WHERE SCHEMA_NAME='imip_ecb';
"

查询结果:

SCHEMA_NAME | DEFAULT_CHARACTER_SET_NAME | DEFAULT_COLLATION_NAME
----------- | -------------------------- | ------------------------
imip_ecb    | utf8mb4                    | utf8mb4_general_ci

目的:记录当前库的字符集/排序规则,确保重建数据库时保持一致。

2. 创建“恢复前快照”备份目录

mkdir -p /data/backup_mysql/manual_before_restore

目的:单独存放本次覆盖前的手工备份,便于必要时回滚。

3. 对覆盖前的imip_ecb做一次完整逻辑备份

mysqldump --single-transaction --quick --lock-tables=false \
  imip_ecb > /data/backup_mysql/manual_before_restore/imip_ecb-before-restore-`date +%F`.sql

确认备份文件存在:

cd /data/backup_mysql/manual_before_restore
ll
# imip_ecb-before-restore-2025-12-11.sql

目的:为本次覆盖恢复保留一份“恢复前状态”的 SQL 备份。

4. 删除原有imip_ecb数据库(为覆盖恢复做准备)

mysql -u root -p -e "DROP DATABASE IF EXISTS imip_ecb;"

目的:清理旧库,避免恢复过程中与原有对象冲突,确保是“重建 + 导入”的干净覆盖。

5. 按原字符集/排序规则重建imip_ecb数据库

mysql -u root -p -e "
CREATE DATABASE imip_ecb
  DEFAULT CHARACTER SET utf8mb4
  COLLATE utf8mb4_general_ci;
"

目的:与恢复前字符集/排序规则保持一致,避免编码相关问题。

6. 使用 2025-12-11 备份文件对imip_ecb进行覆盖恢复

zcat /data/backup_mysql/imip_ecb/imip_ecb-2025-12-11.sql.gz \
  | mysql -u root -p imip_ecb

目的:通过 zcat 解压 .sql.gz,并通过管道将逻辑备份数据导入到新建的 imip_ecb 库,实现在源实例上的覆盖恢复

7. 恢复后检查:确认数据库存在

mysql -u root -p -e "SHOW DATABASES LIKE 'imip_ecb';"

8. 恢复后检查:确认业务表已成功恢复

mysql -u root -p -D imip_ecb -e "SHOW TABLES;"

输出包含业务表,例如:

EMS_EQUIPMENT_INFO
EMS_INSPECT_TASK
EMS_MAINTENANCE_WORK_ORDER
ERP_STOCK
ERP_STOCK_IN
ERP_STOCK_OUT
ERP_SUPPLIER
ERP_WAREHOUSE
infra_task_attachment
...

目的:确认 EMS/ERP 相关业务表均已从备份中成功恢复,库结构完整。

以上就是MySQL自动备份与覆盖恢复实战指南的详细内容,更多关于MySQL自动备份与覆盖恢复的资料请关注脚本之家其它相关文章!

相关文章

  • MySQL递归查询的几种实现方法

    MySQL递归查询的几种实现方法

    本文主要介绍了MySQL递归查询的几种实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-10-10
  • Linux上通过binlog文件恢复mysql数据库详细步骤

    Linux上通过binlog文件恢复mysql数据库详细步骤

    binglog文件是服务器的二进制日志记录着该数据库的所有增删改的操作日志,接下来通过本文给大家介绍linux上通过binlog文件恢复mysql数据库详细步骤,非常不错,需要的朋友参考下
    2016-08-08
  • Linux远程部署MySQL数据库详细步骤

    Linux远程部署MySQL数据库详细步骤

    这篇文章主要介绍了Linux远程部署MySQL数据库的详细步骤,文中步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • 深入浅出的学习Mysql

    深入浅出的学习Mysql

    最近看了一本小书,网易技术部的《深入浅出MySQL数据库开发、优化与管理维护》,算是回顾一下mysql基础知识。下面这篇文章主要介绍了学习Mysql的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • 在IntelliJ IDEA中使用Java连接MySQL数据库的方法详解

    在IntelliJ IDEA中使用Java连接MySQL数据库的方法详解

    这篇文章主要介绍了在IntelliJ IDEA中使用Java连接MySQL数据库的方法详解,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • MySql如何获取相邻数据

    MySql如何获取相邻数据

    这篇文章主要介绍了MySql如何获取相邻数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • 选择MySQL数据库进行连接的简单示例

    选择MySQL数据库进行连接的简单示例

    这篇文章主要介绍了选择MySQL数据库进行连接的简单示例,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-05-05
  • 解决mysql的int型主键自增问题

    解决mysql的int型主键自增问题

    这篇文章主要介绍了解决mysql的int型主键自增问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • MyCat 垂直分片和水平拆分的实现

    MyCat 垂直分片和水平拆分的实现

    本文主要介绍了MyCat 垂直分片和水平拆分的实现,垂直分片将不同类型的表拆分到不同的数据库服务器上,水平拆分则将大表拆分到多个服务器上,下面就来具体介绍一下,感兴趣的可以了解一下
    2025-03-03
  • MySQL存储过程及语法详解

    MySQL存储过程及语法详解

    这篇文章主要介绍了MySQL存储过程及语法详解,存储过程,也叫做存储程序,是一条或者多条SQL语句的集合,可以视为批量处理,但是其作用不仅仅局限于批量处理
    2022-08-08

最新评论