Linux 定时备份 MySQL 数据库(完整教程)

为了防止数据丢失,我们需要定时把数据备份起来。

我们使用用 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 删掉即可,更安全。

相关推荐
小政同学1 分钟前
【NFS故障】共享的文件无法执行
linux·运维·服务器
AI木马人21 分钟前
3.【Prompt工程实战】如何设计一个可复用的Prompt系统?(避免每次手写提示词)
linux·服务器·人工智能·深度学习·prompt
ch3nyuyu33 分钟前
Ubuntu(乌班图)基础指令
linux·运维·网络
minglie11 小时前
gcc编译器汇总
linux
挽安学长1 小时前
保姆级教程,通过GACCode使用Claude Code Desktop!
运维·服务器
sunshine8851 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA2 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
firstacui2 小时前
MGRE实验
运维·服务器·网络
zhangchaoxies2 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
陈陈CHENCHEN2 小时前
【数据库】MySQL 8.0.40 至 8.0.44 RPM 方式升级指南
数据库·mysql