在Docker容器化部署成为主流的今天MySQL数据库的备份与还原面临着“环境隔离”与“数据安全”的双重挑战。传统全库备份不仅占用大量资源还难以应对单库异常的快速恢复需求。
本文基于实战经验详细介绍Docker环境下MySQL全库分离备份方案——通过按业务库拆分备份、自动化脚本执行、压缩存储等技术实现“轻量备份-精准还原-安全存储”的全流程管理。
执行docker ps | grep pxc或者docker ps | grep mysql查看mysql容器一般是3306端口的那个容器记录容器id一般为第一列
#修改以下脚本中的配置项内容直接执行以下命令即可完成数据库备份
cat > /bak/bak.sh << 'EOF'#!/bin/bash# ========== 配置请根据实际情况修改 ==========CONTAINER_NAME="xxxxx" #您的MySQL容器名称或idBACKUP_DIR="/bak/mysql" #修改为要备份的位置目录MYSQL_USER="xxxxx" #修改为真实数据库用户名MYSQL_PASSWORD="xxxxx" #修改为真实数据库密码DATE=$(date +%Y%m%d_%H%M%S)# ========== 创建备份目录==========mkdir -p ${BACKUP_DIR}# ========== 获取数据库列表过滤系统库 ==========DATABASES=$(docker exec ${CONTAINER_NAME} mysql -u${MYSQL_USER} -p${MYSQL_PASSWORD} -e "SHOW DATABASES;" 2>/dev/null | grep -Ev "^(Database|information_schema|performance_schema|mysql|sys)$")# ========== 逐个备份 ==========for DB in ${DATABASES}; do echo "正在备份数据库: ${DB}" BACKUP_FILE="${BACKUP_DIR}/${DB}_${DATE}.sql" docker exec ${CONTAINER_NAME} mysqldump -u${MYSQL_USER} -p${MYSQL_PASSWORD} --single-transaction --routines --triggers --events -B ${DB} > ${BACKUP_FILE} 2>/dev/null if [ $? -eq 0 ]; then echo "✓ 备份成功: ${BACKUP_FILE}" else echo "✗ 备份失败: ${DB}" rm -f ${BACKUP_FILE} fidoneecho "所有数据库备份完成备份目录${BACKUP_DIR}"EOFchmod +x /bak/bak.shecho "已更新并添加执行权限开始备份数据库"/bak/bak.shtar -czf /bak/mysql_backup_$(date +%Y%m%d_%H%M%S).tar.gz -C /bak mysql
注意如果在Windows上创建的脚本在粘贴到Linux后需要将Windows 风格的换行符CRLF即rn换成 Linux 系统期望的是 Unix 风格的换行符LF即n执行以下命令即可sed -i 's/r$//' /bak/bak.sh
执行docker ps | grep pxc或者docker ps | grep mysql查看mysql容器一般是3306端口的那个容器记录容器id一般为第一列
#创建目录bakmkdir -p /bak/mysql#解压缩命令tar -zxvf /bak/mysql_backup_20260608_112915.tar.gz -C /bak
#修改以下脚本中的配置项内容直接执行以下命令即可完成数据库恢复
cat > /bak/restore.sh << 'EOF'#!/bin/bash# ===== 配置区与备份脚本保持一致 =====================CONTAINER_NAME="xxxxx" #您的MySQL容器名称或idBACKUP_DIR="/bak/mysql" #修改为备份文件的位置目录MYSQL_USER="xxxxx" #修改为真实数据库用户名MYSQL_PASSWORD="xxxxx" #修改为真实数据库密码# =============================================# 颜色输出RED='33[0;31m'GREEN='33[0;32m'YELLOW='33[1;33m'NC='33[0m'# 定义需要跳过的系统数据库列表恢复时忽略SKIP_DATABASES=( "mysql" "information_schema" "performance_schema" "sys" "test")# 校验备份目录if [ ! -d "${BACKUP_DIR}" ]; then echo -e "${RED}错误备份目录 ${BACKUP_DIR} 不存在${NC}" exit 1fi# 检查容器是否运行if ! docker ps --filter "id=${CONTAINER_NAME}" --format "{{.ID}}" | grep -q "${CONTAINER_NAME}"; then echo -e "${RED}错误容器 ${CONTAINER_NAME} 未运行或不存在${NC}" exit 1fi# 测试 MySQL 连接echo -e "${YELLOW}测试 MySQL 连接...${NC}"if ! docker exec -i "${CONTAINER_NAME}" mysql -u"${MYSQL_USER}" -p"${MYSQL_PASSWORD}" -e "SELECT 1;" >/dev/null 2>&1; then echo -e "${RED}错误无法连接 MySQL请检查用户名或密码${NC}" exit 1fiecho -e "${GREEN}✓ 连接成功${NC}"# 统计变量TOTAL=0SUCCESS=0SKIPPED=0FAILED=0# 遍历所有 sql 文件for SQL_FILE in "${BACKUP_DIR}"/*.sql; do [ -e "$SQL_FILE" ] || continue # 提取数据库名删除末尾时间戳_YYYYMMDD_HHMMSS.sql保留完整名称含 - 等特殊字符 DB_NAME=$(basename "${SQL_FILE}" | sed 's/_[0-9]{8}_[0-9]{6}.sql$//') # 检查是否在跳过列表中 SKIP=0 for SKIP_DB in "${SKIP_DATABASES[@]}"; do if [ "${DB_NAME}" == "${SKIP_DB}" ]; then SKIP=1 break fi done if [ ${SKIP} -eq 1 ]; then echo "==========================================" echo -e "${YELLOW}⏭ 跳过系统数据库${DB_NAME}${NC}" ((SKIPPED++)) continue fi echo "=============================================" echo -e "${YELLOW}开始恢复数据库${DB_NAME}${NC}" echo "文件${SQL_FILE}" ((TOTAL++)) # 执行恢复捕获输出 TEMP_LOG=$(mktemp) docker exec -i "${CONTAINER_NAME}" mysql -u"${MYSQL_USER}" -p"${MYSQL_PASSWORD}" --force < "${SQL_FILE}" > "${TEMP_LOG}" 2>&1 EXIT_CODE=$? # 判断是否真正失败排除 ERROR 1105PXC 严格模式警告 OTHER_ERRORS=$(grep -i "ERROR" "${TEMP_LOG}" | grep -v "ERROR 1105") if [ ${EXIT_CODE} -eq 0 ] && [ -z "${OTHER_ERRORS}" ]; then # 检查是否只有 1105 警告 # if grep -qi "ERROR 1105" "${TEMP_LOG}"; then # echo -e "${YELLOW}⚠ 检测到 PXC 严格模式警告已忽略数据已正常恢复${NC}" # fi echo -e "${GREEN}✅ ${DB_NAME} 恢复成功${NC}" ((SUCCESS++)) else echo -e "${RED}❌ ${DB_NAME} 恢复失败错误信息${NC}" if [ -n "${OTHER_ERRORS}" ]; then echo "${OTHER_ERRORS}" | head -10 else tail -5 "${TEMP_LOG}" fi ((FAILED++)) fi rm -f "${TEMP_LOG}"done# 输出汇总echo "============================================="echo -e "${GREEN}批量恢复执行完毕${NC}"echo "总计处理$((TOTAL + SKIPPED)) 个文件"echo " ✅ 成功恢复${SUCCESS}"echo " ⏭ 跳过系统库${SKIPPED}"if [ ${FAILED} -gt 0 ]; then echo -e " ${RED}❌ 恢复失败${FAILED}${NC}"else echo " ❌ 恢复失败0"fiEOFchmod +x /bak/restore.shecho "已更新并添加执行权限开始恢复数据库"/bak/restore.sh
这套Docker环境下的MySQL全库分离备份还原方案适合中小规模业务脚本可直接复用。核心是按库分离备份方便单独还原某个库和自动化脚本减少人工操作。可以结合crontab设置定时备份比如每天凌晨3点执行
crontab -e # 添加一行0 3 * * * /bak/bak.sh && tar -czf /bak/mysql_backup_$(date +%Y%m%d).tar.gz -C /bak mysql --remove-files
数据安全无小事定期备份+定期还原测试才能确保关键时刻不掉链子。有问题欢迎在评论区交流觉得有用的话别忘了点赞收藏
以上就是Docker环境下的MySQL全库分离备份及还原教程的详细内容更多关于Docker下MySQL分离备份及还原的资料请关注本站其它相关文章
您可能感兴趣的文章: