【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
相关推荐
牛奔3 分钟前
Docker Compose 两种安装与使用方式详解(适用于 Docker 19.03 版本)
运维·docker·云原生·容器·eureka
富士康质检员张全蛋7 分钟前
JDBC 连接池
数据库
yangminlei16 分钟前
集成Camunda到Spring Boot项目
数据库·oracle
翼龙云_cloud23 分钟前
阿里云渠道商:如何手动一键扩缩容ECS实例?
运维·服务器·阿里云·云计算
Sean X36 分钟前
Ubuntu24.04安装向日葵
linux·ubuntu
ChineHe1 小时前
Redis数据类型篇002_详解Strings核心命令与存储结构
数据库·redis·缓存
清水白石0082 小时前
《从零到进阶:Pydantic v1 与 v2 的核心差异与零成本校验实现原理》
数据库·python
DX_水位流量监测2 小时前
大坝安全监测之渗流渗压位移监测设备技术解析
大数据·运维·服务器·网络·人工智能·安全
电商API&Tina2 小时前
京东 API 数据采集接口接入与行业分析
运维·服务器·网络·数据库·django·php
IT 乔峰2 小时前
脚本部署MHA集群
linux·shell