MySQL数据库自动备份方法

MySQL数据库自动备份方法

有过一次被黑客劫持数据库并勒索比特币的经历后,才知道数据备份的重要性

记录一下方法

一、编写备份脚本

创建一个Shell脚本文件(例如 /opt/scripts/mysql_backup.sh),内容如下:

sh 复制代码
#!/bin/bash

# 数据库配置
DB_USER="your_username"
DB_PASSWORD="your_password"

# 获取所有数据库列表(排除系统数据库)
DB_LIST=$(mysql -u$DB_USER -p$DB_PASSWORD -e "SHOW DATABASES;" | grep -Ev "(Database|information_schema|performance_schema|mysql|sys)")

# 备份配置
BACKUP_DIR="/path/to/your/backup/directory"
DATE=$(date +"%Y%m%d")

# 创建日期目录
TODAY_DIR="$BACKUP_DIR/$DATE"
mkdir -p $TODAY_DIR

# 循环备份每个非系统数据库
for DB_NAME in $DB_LIST; do
    BACKUP_FILE="$TODAY_DIR/${DB_NAME}.sql.gz"
    mysqldump -u$DB_USER -p$DB_PASSWORD $DB_NAME | gzip > $BACKUP_FILE
done

# 清理30天前的旧备份
find $BACKUP_DIR -type d -name "20*" -mtime +30 -exec rm -rf {} \; 2>/dev/null

注意,以上是备份所有的非系统数据库

如果想备份单个数据库,可以简单点,如下:

sh 复制代码
#!/bin/bash

# 数据库配置
DB_USER="your_username"
DB_PASSWORD="your_password"
DB_NAME="your_database_name"

# 备份配置
BACKUP_DIR="/path/to/your/backup/directory" # 请替换为你的目标目录
DATE=$(date +"%Y%m%d_%H%M%S")
BACKUP_FILE="$BACKUP_DIR/${DB_NAME}_backup_$DATE.sql"

# 执行备份
mysqldump -u$DB_USER -p$DB_PASSWORD $DB_NAME > $BACKUP_FILE

# (可选)压缩备份文件以节省空间
gzip $BACKUP_FILE

# (可选)清理超过N天的旧备份,例如保留30天
find $BACKUP_DIR -name "${DB_NAME}_backup_*.sql.gz" -mtime +30 -delete

如果想备份多个数据库,参考如下:

sh 复制代码
#!/bin/bash

# 数据库配置
DB_USER="your_username"
DB_PASSWORD="your_password"

# 要备份的数据库列表,用空格分隔
DB_LIST="database1 database2 database3"

# 备份配置
BACKUP_DIR="/path/to/your/backup/directory"
DATE=$(date +"%Y%m%d")
TIME=$(date +"%H%M%S")

# 创建日期目录
TODAY_DIR="$BACKUP_DIR/$DATE"
mkdir -p $TODAY_DIR

# 日志文件
LOG_FILE="$BACKUP_DIR/backup.log"

# 记录备份开始时间
echo "===== 备份开始: $(date '+%Y-%m-%d %H:%M:%S') =====" >> $LOG_FILE

# 循环备份每个数据库
for DB_NAME in $DB_LIST; do
    BACKUP_FILE="$TODAY_DIR/${DB_NAME}_${TIME}.sql"
    COMPRESSED_FILE="${BACKUP_FILE}.gz"
    
    echo "正在备份数据库: $DB_NAME" >> $LOG_FILE
    
    # 执行备份
    if mysqldump -u$DB_USER -p$DB_PASSWORD $DB_NAME > $BACKUP_FILE 2>> $LOG_FILE; then
        echo "  - 备份成功: $DB_NAME" >> $LOG_FILE
        
        # 压缩备份文件
        if gzip -f $BACKUP_FILE; then
            echo "  - 压缩成功: $COMPRESSED_FILE" >> $LOG_FILE
        else
            echo "  - 压缩失败: $BACKUP_FILE" >> $LOG_FILE
        fi
    else
        echo "  - 备份失败: $DB_NAME" >> $LOG_FILE
    fi
done

# (可选)清理超过N天的旧备份,例如保留30天
DAYS_TO_KEEP=30
find $BACKUP_DIR -type d -name "20*" -mtime +$DAYS_TO_KEEP -exec rm -rf {} \; 2>/dev/null
echo "已清理超过${DAYS_TO_KEEP}天的旧备份" >> $LOG_FILE

# 记录备份结束时间
echo "===== 备份完成: $(date '+%Y-%m-%d %H:%M:%S') =====" >> $LOG_FILE
echo "" >> $LOG_FILE

重要提示 :请务必将脚本中的 your_usernameyour_passwordyour_database_name/path/to/your/backup/directory替换为你实际的数据库信息和服务器目录路径。

二、设置脚本权限

在终端执行以下命令,使脚本具有可执行权限:

bash 复制代码
chmod +x /opt/scripts/mysql_backup.sh

三、配置定时任务

使用 crontab -e命令编辑当前用户的定时任务,添加一行来设置每天自动执行。例如,设置为每天凌晨3点执行备份:

bash 复制代码
0 3 * * * /opt/scripts/mysql_backup.sh

这行配置的含义是:在每天的第0分钟、第3小时(即凌晨3:00)执行一次备份脚本。

四、测试备份

bash 复制代码
bash /opt/scripts/mysql_backup.sh

如果能在备份目录中找到备份的数据库文件,就表明脚本文件生效了,会定时执行,不放心的话可以第二天来看看有没有正常备份

相关推荐
AC赳赳老秦2 分钟前
OpenClaw数据库高效操作指南:MySQL/PostgreSQL批量处理与数据迁移实战
大数据·数据库·mysql·elasticsearch·postgresql·deepseek·openclaw
一 乐9 分钟前
校园线上招聘|基于springboot + vue校园线上招聘系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园线上招聘系统
liliangcsdn10 分钟前
如何基于sentence_transformers构建向量计算工具
数据库·人工智能·全文检索
rchmin26 分钟前
向量数据库Milvus安装及使用实战经验分享
数据库·milvus
ego.iblacat32 分钟前
Python 连接 MySQL 数据库
数据库·python·mysql
祖传F8743 分钟前
quickbi数据集数据查询时间字段显示正确,仪表板不显示
数据库·sql·阿里云
Leon-Ning Liu1 小时前
Oracle 26ai新特性:时区、表空间、审计方面的新特性
数据库·oracle
humors2211 小时前
各厂商工具包网址
java·数据库·python·华为·sdk·苹果·工具包
Yushan Bai2 小时前
ORACLE数据库在进行DROP TABLE时失败报错ORA-00604问题的分析处理
数据库·oracle
77美式2 小时前
Node + Express + MongoDB 后端部署全解析:新手零踩坑
数据库·mongodb·express