当前位置: 首页 > news >正文

备份docker的数据库文件信息

#!/bin/bash

# 配置参数
CONTAINER_ID="*****"        # Docker 容器 ID
DB_USER="root"                     # MySQL 用户名
DB_PASSWORD="****"          # MySQL 密码
DB_NAME="***"                  # 需要备份的数据库名
BACKUP_DIR="/root/data_backup"      # 备份文件和日志的存放目录
BACKUP_FILE="customer_$(date +%Y%m%d).sql"  # 备份文件名
CONTAINER_BACKUP_PATH="/tmp/$BACKUP_FILE"  # 容器内临时备份路径
LOG_FILE="$BACKUP_DIR/mysql_backup.log"    # 日志文件
MAX_BACKUPS=10  # 最多保留的备份文件数

# 确保日志文件和备份目录存在
mkdir -p $BACKUP_DIR
touch $LOG_FILE

# 记录开始时间
echo "[$(date '+%Y-%m-%d %H:%M:%S')] 开始备份数据库..." | tee -a $LOG_FILE

# 1️⃣ 在 Docker 容器内执行 `mysqldump` 备份
docker exec $CONTAINER_ID sh -c "mysqldump -u$DB_USER -p$DB_PASSWORD $DB_NAME > $CONTAINER_BACKUP_PATH"
if [ $? -eq 0 ]; then
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] 数据库备份成功:$CONTAINER_BACKUP_PATH" | tee -a $LOG_FILE
else
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] ❌ 数据库备份失败" | tee -a $LOG_FILE
    exit 1
fi

# 2️⃣ 复制备份文件到宿主机
docker cp $CONTAINER_ID:$CONTAINER_BACKUP_PATH $BACKUP_DIR/
if [ $? -eq 0 ]; then
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] 备份文件成功复制到宿主机:$BACKUP_DIR/$BACKUP_FILE" | tee -a $LOG_FILE
else
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] ❌ 备份文件复制失败" | tee -a $LOG_FILE
    exit 1
fi

# 3️⃣ 删除容器内的备份文件
docker exec $CONTAINER_ID rm -f $CONTAINER_BACKUP_PATH
if [ $? -eq 0 ]; then
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] 容器内临时备份文件删除成功" | tee -a $LOG_FILE
else
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] ⚠️ 容器内临时备份文件删除失败,请手动检查" | tee -a $LOG_FILE
fi

# 4️⃣ 仅保留最新的 10 份备份文件,删除多余的
BACKUP_COUNT=$(ls -1 $BACKUP_DIR/customer_*.sql 2>/dev/null | wc -l)
if [ $BACKUP_COUNT -gt $MAX_BACKUPS ]; then
    DELETE_COUNT=$((BACKUP_COUNT - MAX_BACKUPS))
    echo "[$(date '+%Y-%m-%d %H:%M:%S')] 备份文件超过 $MAX_BACKUPS 份,正在删除最旧的 $DELETE_COUNT 份..." | tee -a $LOG_FILE
    ls -1t $BACKUP_DIR/customer_*.sql | tail -n $DELETE_COUNT | xargs rm -f
    if [ $? -eq 0 ]; then
        echo "[$(date '+%Y-%m-%d %H:%M:%S')] 旧备份文件删除成功" | tee -a $LOG_FILE
    else
        echo "[$(date '+%Y-%m-%d %H:%M:%S')] ❌ 旧备份文件删除失败,请检查" | tee -a $LOG_FILE
    fi
fi

# 5️⃣ 记录备份完成时间
echo "[$(date '+%Y-%m-%d %H:%M:%S')] ✅ 数据库备份流程完成!" | tee -a $LOG_FILE
exit 0

相关文章:

  • PMP项目管理—资源管理篇—1.规划资源管理
  • 【Python爬虫】爬取公共交通路网数据
  • 大语言模型 智能助手——既能生成自然语言回复,又能在必要时调用外部工具获取实时数据
  • 【零基础到精通Java合集】第二十二集:CMS收集器详解(低延迟的里程碑)
  • 将 MySQL 数据高效导入 Redis
  • JAVA安全—Shiro反序列化CB1链source入口sink执行gadget链
  • Python解决“找出整形数组中占比超过一半的数”问题
  • AI介入软件测试过程可行的环节和帮助机制
  • 科普:“图相似性”与“文本相似性”
  • 【音视频】ffmpeg命令分类查询
  • LabVIEW设备长期稳定运行程序设计要点
  • MySQL安装教程
  • 【数据结构】二叉树总结篇
  • 二百八十五、华为云PostgreSQL——建分区表并设置主键
  • *动态规划(4)
  • 精讲坐标轴系统(Axis)
  • 实现浏览器交互Ai Web Ui-本地化部署的deepseek + Ollama + Page Assist
  • 开源表单、投票、测评平台部署教程
  • 专题二最大连续1的个数|||
  • 嵌入式Linux堆栈管理深度解析:从原理到实践
  • wordpress后台地址更改/长沙网站seo报价
  • wordpress 多数据库/专业seo优化公司
  • 如果自己建立网站/关键字搜索引擎
  • 中国纪检监察报社官网/seo优化排名营销
  • 上海建站网/简述获得友情链接的途径
  • 温州多语言网站建设/网站怎么制作免费的