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

前言

定时备份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
相关推荐
Cat God 0072 小时前
基于 CentOS 7.6 的 MySQL 8.0 主从复制
linux·服务器·mysql·centos
LiYingL2 小时前
AlignGuard-LoRA:一种结合了高效微调和安全保护的新正则化方法
服务器·安全
笨蛋少年派2 小时前
Maxwell数据变更捕获工具简介
数据库·mysql
谷新龙0012 小时前
pg_clickhouse插件,在postgresql中借助clickhouse借用OLAP能力
数据库·clickhouse·postgresql
Hello.Reader2 小时前
Flink SQL 的 SET 语句会话参数配置与快速自检(SQL CLI 实战)
数据库·sql·flink
老华带你飞2 小时前
工会管理|基于springboot 工会管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
自在极意功。2 小时前
MyBatis配置文件详解:environments、transactionManager与dataSource全面解析
java·数据库·tomcat·mybatis
紫金桥软件2 小时前
紫金桥软件 | 赋能工业数字化转型
数据库·国产化
Blueeyedboy5212 小时前
服务器监控工具-netdata
运维·服务器