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

前言

定时备份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
相关推荐
_下雨天.4 小时前
LVS负载均衡
服务器·负载均衡·lvs
mounter6256 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
zzzyyy5387 小时前
Linux环境变量
linux·运维·服务器
等....7 小时前
Minio使用
数据库
kebeiovo7 小时前
atomic原子操作实现无锁队列
服务器·c++
win x8 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
CHHC18808 小时前
NetCore树莓派桌面应用程序
linux·运维·服务器
迷枫7129 小时前
DM8 数据库安装实战:从零搭建达梦数据库环境(附全套工具链接)
数据库
帮我吧智能服务平台9 小时前
装备制造智能制造升级:远程运维与智能服务如何保障产线OEE
运维·服务器·制造
XDHCOM9 小时前
PostgreSQL 25001: active_sql_transaction 报错原因分析,故障修复步骤详解,远程处理解决方案
数据库·sql·postgresql