Linux Mysql数据库自动备份脚本

本文介绍了一款用于自动化MySQL数据库备份的bash脚本,该脚本利用mysqldump命令进行数据库导出,并使用gzip进行压缩,同时具备自动清理15天前备份的功能,确保了数据的安全性和系统的整洁。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方便你我他

#!/bin/bash

#备份文件存储目录
backupdir=/mnt/bak/dump
#时间戳
time=_`date +%Y_%m_%d_%H_%M_%S`
#数据库连接信息
db_name=数据库名称
db_user=数据库账户
db_pass=数据库密码

#mysql备份
mysqldump -u$db_user -p$db_pass $db_name | gzip > $backupdir/$db_name$time.sql.gz

#自动清理15天以前的备份文件
find $backupdir -name $db_name"*.sql.gz" -type f -mtime +15 -exec rm -rf {} \; > /dev/null 2>&1

 

为了确保MySQL数据库的安全性和可恢复性,在Linux环境下设置定期自动备份是非常重要的。下面是一个简单的自动备份脚本示例,它可以帮助你每天定时创建并保存MySQL数据库备份。 ### 自动备份脚本 #### 脚本内容 (`backup_mysql.sh`) ```bash #!/bin/bash # 设置日期格式变量用于区分每次备份 DATE=$(date +%Y%m%d_%H%M%S) # 定义存储备份文件的目标目录 (请根据实际情况修改) BACKUP_DIR="/path/to/your_backup_directory" # 指定 MySQL 登录信息 (如果不需要密码认证,则省略-p选项后的部分) MYSQL_USER="your_username" MYSQL_PASSWORD="your_password" DB_NAME="database_name" # 需要备份的具体数据库名称 # 创建当天日期作为子文件夹存放今天的备份结果 TODAY_BACKUP_PATH="$BACKUP_DIR/$DATE" mkdir -p $TODAY_BACKUP_PATH # 使用 mysqldump 工具导出指定数据库并将输出重定向至新建立好的路径下 mysqldump -u$MYSQL_USER -p"$MYSQL_PASSWORD" $DB_NAME > "$TODAY_BACKUP_PATH/${DB_NAME}_$DATE.sql" if [ $? -eq 0 ]; then echo "Backup succeeded!" else echo "Backup failed!" fi # 删除超过7天旧的备份文件(可根据需要调整保留时间),避免占用过多磁盘空间 find $BACKUP_DIR/* -mtime +7 -exec rm -rf {} \; exit 0; ``` 请注意: - 将 `your_username`, `your_password`, 和 `database_name` 替换成你自己实际使用的值。 - 修改 `/path/to/your_backup_directory` 到你想储存备份的地方。 - 根据需求自定义删除过期备份的时间规则(此处设定为七天前)。 #### 给予执行权限 为了让这个shell script能够被执行,你需要赋予其适当的权限: ```bash chmod +x backup_mysql.sh ``` #### 添加计划任务(crontab) 最后一步就是安排crontab作业以便系统能按预定频率运行此脚本了。你可以按照以下步骤操作: 1. 编辑当前用户的 crontab 文件: ```bash crontab -e ``` 2. 加入一行新的调度表达式以每天凌晨两点整钟触发一次备份任务: ``` 0 2 * * * /full/path/to/backup_mysql.sh >> /var/log/mysql-backup.log 2>&1 ``` 这将会把所有的标准输出和错误都追加到日志文件当中方便日后查看是否有异常情况发生。 --- 通过上述方法配置好之后,你就拥有了一个稳定可靠的Linux平台下的Mysql数据库每日自动备份解决方案啦!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jc_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值