前言
定时备份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