【MySQL逻辑备份】基于mysqldump的MySQL 8.0全量逻辑备份脚本

本脚本为 MySQL 8.0 设计的实例级 mysqldump 逻辑全备脚本,可对整个数据库实例进行备份,完整涵盖数据、表结构、存储过程、函数、事件、触发器等所有对象。

1 备份脚本

bash 复制代码
### mysql_full_backup.sh脚本内容如下:

#!/bin/bash

# MySQL 8.0 全实例自动备份脚本
# 功能:备份所有数据库(包含存储过程、函数、事件、触发器)

# ====== 配置区 ======
# MySQL 连接配置
MYSQL_USER="root"                    # MySQL 用户名
MYSQL_PASS="your_password"           # MySQL 密码(建议使用配置文件免密)
MYSQL_HOST="localhost"               # MySQL 主机
MYSQL_PORT="3306"                    # MySQL 端口

# 备份路径配置
BACKUP_BASE_DIR="/data/mysql_backup"            # 备份根目录
DATE_STAMP=$(date +"%Y%m%d_%H%M%S")            # 时间戳格式
BACKUP_DIR="${BACKUP_BASE_DIR}/full_${DATE_STAMP}"  # 本次备份目录

# 备份保留天数(自动清理旧备份)
RETENTION_DAYS=7

# 日志文件
LOG_FILE="${BACKUP_BASE_DIR}/backup.log"

# ====== 函数定义 ======
# 记录日志函数
log_message() {
    echo "[$(date +'%Y-%m-%d %H:%M:%S')] $1" >> ${LOG_FILE}
}

# 检查错误函数
check_error() {
    if [ $? -ne 0 ]; then
        log_message "错误: $1"
        exit 1
    fi
}

# ====== 主程序开始 ======
log_message "=== MySQL全量备份开始 ==="

# 1. 创建备份目录
mkdir -p ${BACKUP_DIR}
check_error "创建备份目录失败"

# 2. 设置权限(保护备份文件)
chmod 750 ${BACKUP_DIR}
log_message "备份目录创建成功: ${BACKUP_DIR}"

# 3. 执行全实例备份(关键参数说明)
log_message "开始执行mysqldump全实例备份..."

mysqldump --user=${MYSQL_USER} \
          --password=${MYSQL_PASS} \
          --host=${MYSQL_HOST} \
          --port=${MYSQL_PORT} \
          --all-databases \
          --single-transaction \
          --routines \
          --events \
          --triggers \
          --flush-logs \
          --source-data=2 \
          --set-gtid-purged=OFF \
          --default-character-set=utf8mb4 \
          --max-allowed-packet=1G \
          --hex-blob \
          --result-file=${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql

check_error "mysqldump备份执行失败"

log_message "MySQL全实例备份完成: ${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql"

# 4. 备份MySQL配置文件(重要!)
cp /etc/my.cnf ${BACKUP_DIR}/my.cnf_backup_${DATE_STAMP} 2>/dev/null || log_message "警告: 未找到/etc/my.cnf,跳过配置文件备份"

# 5. 压缩备份文件(节省空间)
log_message "开始压缩备份文件..."
gzip ${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql
check_error "备份文件压缩失败"
log_message "备份文件压缩完成: ${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql.gz"

# 6. 生成MD5校验文件(验证备份完整性)
md5sum ${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql.gz > ${BACKUP_DIR}/backup.md5
log_message "生成MD5校验文件"

# 7. 清理旧备份(按保留天数设置)
log_message "清理${RETENTION_DAYS}天前的旧备份..."
find ${BACKUP_BASE_DIR} -name "full_*" -type d -mtime +${RETENTION_DAYS} -exec rm -rf {} \; 2>/dev/null

# 8. 输出备份信息
BACKUP_SIZE=$(du -sh ${BACKUP_DIR} | cut -f1)
log_message "备份完成! 备份大小: ${BACKUP_SIZE}, 备份位置: ${BACKUP_DIR}"

# 9. 验证备份文件完整性
log_message "验证备份文件完整性..."
md5sum -c ${BACKUP_DIR}/backup.md5 >> ${LOG_FILE} 2>&1
if [ $? -eq 0 ]; then
    log_message "备份文件完整性验证通过"
else
    log_message "警告: 备份文件完整性验证失败"
fi

log_message "=== MySQL全量备份结束 ==="
echo "备份已完成! 文件位置: ${BACKUP_DIR}/mysql_full_backup_${DATE_STAMP}.sql.gz"

脚本名称命名为 mysql_full_backup.sh

2 使用教程

bash 复制代码
1. 保存脚本并赋予执行权限
chmod +x mysql_full_backup.sh

2. 配置MySQL免密认证​​(可选推荐,避免密码明文)
 在/root/.my.cnf中添加:
[client]
user=root
password=your_password
host=localhost
port=3306
然后设置权限:chmod 600 /root/.my.cnf

3. 手动执行备份
./mysql_full_backup.sh

4. 配置定时任务(每日凌晨0点执行)
# 编辑crontab:crontab -e 添加如下内容并保存
0 0 * * * /path/to/mysql_full_backup.sh

3 恢复备份​​

bash 复制代码
# 解压备份文件
gunzip mysql_full_backup_20251117_152500.sql

# 恢复到MySQL
mysql -u root -p < mysql_full_backup_20251117_152500.sql
相关推荐
深紫色的三北六号8 小时前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash12 小时前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
哈基咪怎么可能是AI1 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
于眠牧北1 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
十日十行2 天前
Linux和window共享文件夹
linux
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
木心月转码ing2 天前
WSL+Cpp开发环境配置
linux
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba