帮助中心 >  技术知识库 >  云服务器 >  服务器教程 >  CentOS系统mysql数据库自动备份脚本

CentOS系统mysql数据库自动备份脚本

2016-07-12 23:45:06 5865

  1. #!/bin/bash  

  2.   

  3. databases=(要备份的数据库名)  

  4.   

  5. basepath='/root/backup/'  

  6.   

  7. if [ ! -d "$basepath" ]; then  

  8.     mkdir -p "$basepath"  

  9. fi  

  10.   

  11. for db in ${databases[*]}  

  12.     do  

  13.         /bin/nice -n 19 /usr/bin/mysqldump -u数据库账号 -p数据库密码 --database $db > $basepath$db-$(date +%Y%m%d).sql  

  14.   

  15.         /bin/nice -n 19 tar zPcf $basepath$db-$(date +%Y%m%d).sql.tar.gz $basepath$db-$(date +%Y%m%d).sql  

  16.   

  17.         find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} ;   

  18.     done  

  19.   

  20.   

  21.     #rm -rf $basepath/*.sql  

脚本如上,我这里的脚本为/root/db.sh

备份的地址

basepath='/root/backup/'  

可以自己修改

/bin/nice -n 19是设置优先级

备份数据库的命令是mysqldump,命令在/usr/bin/目录下面

这句代码是删除7天前的备份文件

find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} ;   

这句代码是删除生成的sql中间文件,但是我这里把它注释掉了,也就是说?会删除,如果要删除自己把注释去掉

 #rm -rf $basepath/*.sql  

 注意代码最好是在CentOS系统中手动敲,别在windows系统中敲了再传到CentOS系统中,因为有可能因为编码原因造成脚本运行有问题。

 脚本写好后要通过crontab -e命令设置脚本定时运行

crontab -e

0 3 * * * /root/db.sh

然后保存

这样就是每天凌晨3:00自动运行脚本,即自动备份数据库


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: