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

相关推荐
拾贰_C7 小时前
【Ubuntu | 公共工作站 | mysql 】 MySQL残留物残留数据
linux·mysql·ubuntu
TE-茶叶蛋7 小时前
DBeaver 的Explain 执行计划,分析sql的性能
数据库·sql
临街的小孩7 小时前
Docker 容器内运行 ROS Noetic 图形界面(rqt_image_view)极简教程总结
运维·docker·容器
Ujimatsu8 小时前
虚拟机安装Ubuntu 26.04.x服务器版(命令行版)(2026.5)
linux·windows·ubuntu
CLX05058 小时前
如何安装Oracle 12c Cloud Control_OMS服务端组件与Agent部署
jvm·数据库·python
m0_617493948 小时前
PySide6 网络请求深度实测:从基础 API 调用到数据解析实战指南
数据库
hweiyu008 小时前
Linux命令:arptables
linux·运维
知识汲取者8 小时前
每日一篇高频面试题系列之【MySQL 锁】
数据库·mysql
老纪9 小时前
SQL中如何查找特定的空值行:WHERE IS NULL深度解析
jvm·数据库·python
麦聪聊数据9 小时前
数据 API 平台选型:深度解读数据服务的四大关键技术与架构底座
数据库·sql