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

相关推荐
bush47 小时前
嵌入式linux学习记录七,中断
linux·嵌入式
不会就选b7 小时前
MySQL之视图
数据库·mysql
RisunJan7 小时前
Linux命令-nologin(用于系统账户或需要禁止交互式登录的场景)
linux·运维
是阿建吖!7 小时前
【Linux】信号
android·linux·c语言·c++
城北徐宫7 小时前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
倔强的石头1068 小时前
【Linux指南】Linux快捷键与系统实用技巧
linux·运维·服务器
>no problem<8 小时前
基于cola5.0的基础设施层的多数据库切换方案思路
数据库·spring boot·mybatisplus·cola5.0·数据库迁移适配
番茄地瓜8 小时前
Linux 配置静态 IP 步骤
linux·运维·服务器
OceanBase数据库官方博客8 小时前
OceanBase 赋能央国企:从发电到用电的全链路业务承载
数据库·oceanbase
liulilittle8 小时前
论 Linux 内核态全局稳态带宽的卡尔曼估计与工程实现
linux·服务器·网络·c++·计算机网络·tcp·通信