- 工信部备案号 滇ICP备05000110号-1
- 滇公安备案 滇53010302000111
- 增值电信业务经营许可证 B1.B2-20181647、滇B1.B2-20190004
- 云南互联网协会理事单位
- 安全联盟认证网站身份V标记
- 域名注册服务机构许可:滇D3-20230001
- 代理域名注册服务机构:新网数码
#!/bin/bash
databases=(要备份的数据库名)
basepath='/root/backup/'
if [ ! -d "$basepath" ]; then
mkdir -p "$basepath"
fi
for db in ${databases[*]}
do
/bin/nice -n 19 /usr/bin/mysqldump -u数据库账号 -p数据库密码 --database $db > $basepath$db-$(date +%Y%m%d).sql
/bin/nice -n 19 tar zPcf $basepath$db-$(date +%Y%m%d).sql.tar.gz $basepath$db-$(date +%Y%m%d).sql
find $basepath -mtime +7 -name "*.sql.tar.gz" -exec rm -rf {} ;
done
#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自动运行脚本,即自动备份数据库
售前咨询
售后咨询
备案咨询
二维码
TOP