为了防止数据丢失,我们需要定时把数据备份起来。
我们使用用 Linux crontab + mysqldump 实现定时自动备份,包含备份、压缩、保留历史、自动清理旧文件。
一、先准备备份脚本
创建一个备份脚本 mysql_backup.sh,放在 /usr/local/bin/ 方便管理。
#!/bin/bash
# ====================== 配置项(请修改这里)======================
# MySQL 用户名
MYSQL_USER="root"
# MySQL 密码
MYSQL_PASS="你的MySQL密码"
# MySQL 主机(一般不用改)
MYSQL_HOST="localhost"
# 要备份的数据库名(多个用空格隔开)
DATABASES="db1 db2 db3"
# 备份文件存放目录
BACKUP_DIR="/data/backup/mysql"
# 保留多少天的备份(自动删除过期文件)
DAYS_KEEP=7
# =================================================================
# 创建备份目录(不存在则自动创建)
mkdir -p $BACKUP_DIR
# 获取当前时间
DATE=$(date +%Y%m%d_%H%M%S)
# 循环备份每个数据库
for DB in $DATABASES
do
echo "开始备份数据库:$DB"
mysqldump -h$MYSQL_HOST -u$MYSQL_USER -p$MYSQL_PASS --databases $DB | gzip > $BACKUP_DIR/${DB}_${DATE}.sql.gz
done
# 删除7天前的备份文件
find $BACKUP_DIR -name "*.sql.gz" -mtime +$DAYS_KEEP -delete
echo "MySQL 备份完成!"
二、给脚本执行权限
chmod +x /usr/local/bin/mysql_backup.sh
三、测试脚本是否能正常运行
/usr/local/bin/mysql_backup.sh
✅ 运行后去 /data/backup/mysql/ 看有没有生成 .sql.gz 备份文件,有就说明正常。
四、设置定时任务(crontab)
1. 编辑定时任务
crontab -e
2. 添加定时规则(示例)
# 每天凌晨 2:00 自动备份
0 2 * * * /usr/local/bin/mysql_backup.sh >> /var/log/mysql_backup.log 2>&1
常用定时示例
# 每天凌晨2点备份(推荐)
0 2 * * * /usr/local/bin/mysql_backup.sh >> /var/log/mysql_backup.log 2>&1
# 每6小时备份一次
0 */6 * * * /usr/local/bin/mysql_backup.sh >> /var/log/mysql_backup.log 2>&1
# 每周日凌晨3点备份
0 3 * * 0 /usr/local/bin/mysql_backup.sh >> /var/log/mysql_backup.log 2>&1
3. 查看定时任务是否生效
crontab -l
五、备份文件说明
- 备份路径:
/data/backup/mysql/ - 文件名格式:
库名_20260404_020000.sql.gz - 自动压缩(体积小)
- 自动删除 7 天前的备份
六、恢复备份方法
如果你需要恢复数据,执行:
# 解压
gzip -d 备份文件.sql.gz
# 恢复
mysql -u root -p 库名 < 备份文件.sql
七、安全优化(可选但推荐)
不建议在脚本里明文写密码,更安全的方式:创建 MySQL 配置文件:
vi /etc/my.cnf.d/mysql-backup.cnf
写入:
ini
[mysqldump]
user=root
password=你的密码
host=localhost
然后修改权限:
bash
运行
chmod 600 /etc/my.cnf.d/mysql-backup.cnf
最后把脚本里的 -u$MYSQL_USER -p$MYSQL_PASS 删掉即可,更安全。