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

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

相关推荐
2301_816651222 小时前
如何从Python初学者进阶为专家?
jvm·数据库·python
Aaron_Wjf2 小时前
PostgreSQL大对象操作办法
数据库·postgresql
fundroid2 小时前
Room 3.0 完全解析:一次面向未来的现代化重构
android·数据库·database·kmp
小江的记录本2 小时前
【Redis】Redis常用命令速查表(完整版)
java·前端·数据库·redis·后端·spring·缓存
卓怡学长2 小时前
m281基于SSM框架的电脑测评系统
java·数据库·spring·tomcat·maven·intellij-idea
umeelove352 小时前
SQL中的DISTINCT、SQL DISTINCT详解、DISTINCT的用法、DISTINCT注意事项
java·数据库·sql
@insist1232 小时前
数据库系统工程师-嵌入式 SQL 与存储过程核心原理与应试指南
数据库·sql·软考·数据库系统工程师·软件水平考试
m0_569881472 小时前
使用Python自动收发邮件
jvm·数据库·python
marsh02062 小时前
16 openclaw与数据库集成:ORM使用与性能优化
数据库·spring·ai·性能优化·编程·技术