服务器定时备份数据库脚本

前言

定时备份mysql数据库是服务器的硬性要求,防止出现异常,数据丢失,一般可以定时到凌晨,进行数据备份,以下给出的脚本是全量备份,不需要修改mysql的配置,优点是比较简单。缺点是备份时间比较长。增量备份需要修改mysql配置,打开日志,对于正在运行的项目,不太好停机修改,有可能还会出现异常,适合用户比较少的项目

不需要sudo权限的备份

java 复制代码
[root@iZt4ne5n70035rjpj6m0wzZ ~]# cat  /root/mysql_daily_backup.sh << 'EOF'
 #!/bin/bash
 set -e
 BACKUP_DIR="/root/backup"
 CONTAINER="mysql"
 MYSQL_USER="root"
 MYSQL_PASS="Zxsd@147"
 DATE=$(date +%Y%m%d_%H%M%S)
 
 # 创建目录
 mkdir -p "$BACKUP_DIR"
 
 echo "开始MySQL备份: $(date '+%Y-%m-%d %H:%M:%S')"
 
 # 执行备份
 if docker exec "$CONTAINER" mysqldump -u"$MYSQL_USER" -p"$MYSQL_PASS" \
   --all-databases \
   --single-transaction \
   --quick \
   --routines \
   --events \
   --triggers \
   | gzip  "$BACKUP_DIR/mysql_${DATE}.sql.gz"; then
   
   echo "✓ 备份成功"
   FILE_SIZE=$(du -h "$BACKUP_DIR/mysql_${DATE}.sql.gz" | cut -f1)
   echo "文件大小: $FILE_SIZE"
   
   # 清理30天前的备份
   find "$BACKUP_DIR" -name "mysql_*.sql.gz" -type f -mtime +30 -delete
   
   echo "备份完成"
 else
   echo "✗ 备份失败"
   exit 1
 fi
 EOF
[root@iZt4ne5n70035rjpj6m0wzZ ~]# chmod +x /root/mysql_daily_backup.sh
[root@iZt4ne5n70035rjpj6m0wzZ ~]# /root/mysql_daily_backup.sh
开始MySQL备份: 2025-12-18 14:01:19
mysqldump: [Warning] Using a password on the command line interface can be insecure.
✓ 备份成功
文件大小: 66M
备份完成
[root@iZt4ne5n70035rjpj6m0wzZ ~]# crontab -l | grep mysql
0 2 * * * /root/mysql_daily_backup.sh  /root/backup/logs/cron.log 2&1



恢复
# 恢复最新备份
gunzip < /root/backup/mysql_最新日期.sql.gz | docker exec -i mysql mysql -uroot -pZxsd@147

需要sudo权限的备份

java 复制代码
脚本内容/data/ChipletRing_web/mysql_daily_backup.sh

#!/bin/bash
set -e
BACKUP_DIR="/data/ChipletRing_web/mysql_backup"
CONTAINER="mysql"
MYSQL_USER="root"
MYSQL_PASS="Zxsd@147"
DATE=$(date +%Y%m%d_%H%M%S)

# 创建目录
mkdir -p "$BACKUP_DIR"

echo "开始MySQL备份: $(date '+%Y-%m-%d %H:%M:%S')"
echo "备份目录: $BACKUP_DIR"

# 检查Docker权限(使用sudo)
if ! sudo docker ps >/dev/null 2>&1; then
    echo "错误: 没有Docker执行权限"
    exit 1
fi

# 检查MySQL容器
if ! sudo docker ps | grep -q "$CONTAINER"; then
    echo "错误: MySQL容器 '$CONTAINER' 未运行"
    exit 1
fi

# 执行备份
BACKUP_FILE="$BACKUP_DIR/mysql_${DATE}.sql.gz"
echo "备份文件: $BACKUP_FILE"

# 使用sudo执行docker命令
if sudo docker exec "$CONTAINER" mysqldump -u"$MYSQL_USER" -p"$MYSQL_PASS" \
  --all-databases \
  --single-transaction \
  --quick \
  --routines \
  --events \
  --triggers \
  | gzip > "$BACKUP_FILE"; then
  
  # 检查备份文件是否真的有效(大于1KB)
  FILE_SIZE=$(du -k "$BACKUP_FILE" | cut -f1)
  if [ "$FILE_SIZE" -lt 10 ]; then  # 小于10KB可能有问题
    echo "警告: 备份文件大小异常 ($FILE_SIZE KB),可能备份失败"
    rm -f "$BACKUP_FILE"
    exit 1
  fi
  
  echo "✓ 备份成功"
  FILE_SIZE_H=$(du -h "$BACKUP_FILE" | cut -f1)
  echo "文件大小: $FILE_SIZE_H"
  
  # 清理30天前的备份
  find "$BACKUP_DIR" -name "mysql_*.sql.gz" -type f -mtime +30 -delete
  
  echo "备份完成"
else
  echo "✗ 备份失败"
  exit 1
fi

# 给权限
chmod +x mysql_daily_backup.sh

sudo ./mysql_daily_backup.sh

# 1. 编辑当前用户的crontab
crontab -e

# MySQL每日备份 - 凌晨2点执行
0 2 * * * sudo /data/ChipletRing_web/mysql_daily_backup.sh >> /data/ChipletRing_web/mysql_backup/backup.log 2>&1


恢复
# 恢复最新备份
gunzip < /data/ChipletRing_web/mysql_backup/mysql_最新日期.sql.gz | docker exec -i mysql mysql -uroot -pZxsd@147
相关推荐
yangminlei9 小时前
集成Camunda到Spring Boot项目
数据库·oracle
翼龙云_cloud9 小时前
阿里云渠道商:如何手动一键扩缩容ECS实例?
运维·服务器·阿里云·云计算
墨风如雪9 小时前
拒绝被找回!MJJ必修课:Outlook邮箱交易后的“防回手”安全设置全攻略
服务器
ChineHe10 小时前
Redis数据类型篇002_详解Strings核心命令与存储结构
数据库·redis·缓存
清水白石00810 小时前
《从零到进阶:Pydantic v1 与 v2 的核心差异与零成本校验实现原理》
数据库·python
DX_水位流量监测10 小时前
大坝安全监测之渗流渗压位移监测设备技术解析
大数据·运维·服务器·网络·人工智能·安全
电商API&Tina10 小时前
京东 API 数据采集接口接入与行业分析
运维·服务器·网络·数据库·django·php
柠檬叶子C11 小时前
PostgreSQL 忘记 postgres 密码怎么办?(已解决)
数据库·postgresql
Mr_Xuhhh11 小时前
博客标题:深入理解Shell:从进程控制到自主实现一个微型Shell
linux·运维·服务器
864记忆11 小时前
Qt创建连接注意事项
数据库·qt·nginx