【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
相关推荐
佐杰1 小时前
Jenkins备份管理
java·运维·jenkins
q***47181 小时前
MySQL 篇 - Java 连接 MySQL 数据库并实现数据交互
java·数据库·mysql
t***L2661 小时前
GitLab API使用实例
运维·gitlab
BS_Li1 小时前
【Linux系统编程】基础IO
linux·服务器·文件操作
ALex_zry1 小时前
Docker容器运维与故障排查实战手册
运维·docker·容器
一只爱学习的小鱼儿1 小时前
QT中3D的使用
开发语言·数据库·qt
百***35941 小时前
Linux(CentOS)安装 MySQL
linux·mysql·centos
('-')1 小时前
《从根上理解MySQL是怎样运行的》第五章学习笔记
笔记·学习·mysql
翼龙云_cloud1 小时前
阿里云渠道商:如何在NAS控制台创建通用型NAS NFS协议文件系统?
运维·服务器·阿里云·云计算