首页 > 运维 > linux运维 > 正文

Linux 写一个自动备份数据库的脚本

冷漠man
发布: 2025-12-04 20:54:06
原创
462人浏览过
首先创建Shell脚本配置数据库备份参数,然后设置执行权限并测试备份功能,接着通过cron定时任务实现每日自动备份,最后建议使用.my.cnf加密存储密码以提升安全性。

linux 写一个自动备份数据库的脚本

数据库自动备份是运维中非常基础且重要的任务。下面是一个使用 Shell 编写的 Linux 脚本,用于自动备份 MySQL/MariaDB 数据库,并按日期命名备份文件,同时支持清理过期备份。

1. 创建备份脚本

将以下内容保存为 /backup/db_backup.sh(可自定义路径):

!/bin/bash

# 配置项 DB_USER="root" DB_PASS="your_password" # 建议使用 mysql_config_editor 加密存储密码 DB_NAME="your_database_name" # 指定要备份的数据库名,多个库可用空格分隔 BACKUPDIR="/backup/db" # 备份文件存储目录 DATE=$(date +"%Y%m%d%H%M%S") EXPIRE_DAYS=7 # 自动删除超过 N 天的备份

# 创建备份目录(如果不存在) mkdir -p $BACKUP_DIR

# 生成备份文件名 BACKUP_FILE="$BACKUP_DIR/${DB_NAME}backup$DATE.sql.gz"

# 执行备份并压缩 mysqldump -u$DB_USER -p$DB_PASS $DB_NAME | gzip > $BACKUP_FILE

# 检查备份是否成功 if [ $? -eq 0 ]; then echo "✅ 数据库 '$DB_NAME' 备份成功: $BACKUP_FILE" else echo "❌ 数据库 '$DB_NAME' 备份失败" exit 1 fi

# 删除过期的备份文件 find $BACKUP_DIR -name "${DB_NAME}backup*.sql.gz" -mtime +$EXPIRE_DAYS -delete echo "? 已清理 ${EXPIRE_DAYS} 天前的旧备份"

2. 设置权限与测试

赋予脚本执行权限:

chmod +x /backup/db_backup.sh

手动运行测试:

/backup/db_backup.sh

确认在 /backup/db 目录下生成了类似 your_database_name_backup_20250405_103000.sql.gz 的压缩文件。

3. 配置定时任务(cron)

编辑 root 用户的 crontab:

EZIBI! 商城(原维C商城)
EZIBI! 商城(原维C商城)

前身是vitcie(维C商城),各种特性介绍: 1. 稳定、安全、高效的系统平台 EZIBI!基于PHP+MYSQL技术编写,PHP自1995发布第一个版本,经过近10年的发展,已经成为目前最流行的网络编程语言之一,其强大的数据库支持使得开发人员很轻易的就可以完成C/S架构电子商务平台的构建;MYSQL则是成熟的数据库系统。 2. 安装向导 EZIBI!提供支持多语言版的安装脚本,只需按照提

EZIBI! 商城(原维C商城) 0
查看详情 EZIBI! 商城(原维C商城)
crontab -e

添加一行,例如每天凌晨 2 点执行备份:

0 2 * * * /backup/db_backup.sh >> /backup/db_backup.log 2>&1

这样每次运行日志会记录到 /backup/db_backup.log,便于排查问题。

4. 安全建议

  • 不要在脚本中明文写密码:可使用 ~/.my.cnf 文件存储凭证
  • 设置 .my.cnf 权限为 600:
[client] user = root password = your_password

然后修改脚本中的 mysqldump 命令为:

mysqldump $DB_NAME | gzip > $BACKUP_FILE

更安全且简洁。

基本上就这些。脚本简单可靠,适合中小项目使用。

以上就是Linux 写一个自动备份数据库的脚本的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号