代码改变世界

Linux实现定时备份MySQL数据库并删除30天前的备份文件

  猎手家园  阅读(1510)  评论(0编辑  收藏  举报

1. MySQL5.6以上版本

2. 修改 /etc/my.cnf 文件

# vim /etc/my.cnf

[client]
host=localhost
user=你的数据库用户
password='你的数据库密码'

 

3. 编写数据库脚本 mysql-backup.sh

复制代码
# vim mysql-backup.sh
#!/bin/bash

backupDir=数据库备份目录
backupTime=`date +%Y%m%d%H%M%S`

mysqldump 你的数据库 | gzip > $backupDir/你的数据库-$backupTime.sql.gz
echo "1."$backupTime "备份完成" >> #backupDir/mysql.log

cd $backupDir
rm -rf `find . -name '*.sql.gz' -mtime +30` >> #backupDir/mysql.log 2>&1    #删除30天前备份文件
echo "2.删除30天前的备份文件完成" >> #backupDir/mysql.log
复制代码

 

4. 为脚本添加执行权限

# chmod +x mysql-backup.sh

 

5. 测试执行

./mysql-backup.sh

 

6. 添加定时计划

# crontab -e (和vim编辑器一样)
# crontab配置文件格式:分 时 日 月 周  命令

# 在最后一行中加入:
0 3 * * *   /usr/sbin/mysql-bakup.sh #表示每天3点00分执行备份
0 */6 * * * /usr/sbin/mysql-bakup.sh #表示每6个小时执行备份

# crontab -l 列出所有定时任务

 

7. 重启crontab

# /etc/rc.d/init.d/crond restart

 

注:Centos8执行crond命令

systemctl restart crond.service

#支持的命令有:start、stop、restart、reload、status

 

8. 恢复数据库备份文件

#SQL备份文件恢复:
mysql -u root -p 你的数据库 < 备份文件名.sql

#压缩文件恢复:
gzip < 备份文件名.sql.gz | mysql -u root -p 你的数据库

 

9. 附:如果出现问题:"mysqldump: command not found",解决如下:

ln -fs /usr/local/mysql/bin/mysqldump /usr/bin
ln -fs /usr/local/mysql/bin/mysql /usr/bin

 

编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示