linux系统自带的cron 定时备份数据库
本来在代码里面写了一个定时任务,每隔10分钟定时备份数据库,其他项目都没问题,原来部署的docker项目都没问题,这次新部署一个项目定时任务总是报错,报错信息:nsenter: reassociate to namespace 'ns/ipc' failed: Operation not permitted。弄起来觉得麻烦,就想了另外一个方法,利用linux系统带的crontab进行定时执行备份任务。centos 7.X系统。
有需要的直接拿去用......
1、创建备份脚本
进入目录 /usr/local/bin/ 创建一个mysql_backup.sh 脚本,脚本名称可以自己定义。并且付给读写执行权限 chmod 777 mysql_backup.sh
创建完成之后,写脚本内容,贴在下面(记住要一行一行复制,否则可能会报错bad interpreter: Text file busy):
#!/bin/bash
# 配置参数
BACKUP_DIR="/home/tono/sql"
FILENAME="$BACKUP_DIR/tono_$(date +\%Y\%m\%d-\%H\%M).sql"
# 执行备份语句
docker exec polo-mysql mysqldump -uroot -pkenuo@2022 --databases tono > "$FILENAME"
# 验证备份结果
if [ $? -eq 0 ]; then
echo "[$(date)] succes: $FILENAME" >> /var/log/mysql_backup.log
else
echo "[$(date)] fail: $?" >> /var/log/mysql_backup.log
fi
# 清理旧备份(保留最近4个文件)
find $BACKUP_DIR -name "tono_*.sql" -type f | sort -r | tail -n +4 | xargs rm -f --
2**、linux创建任务计划执行以上脚本**
在宿主机:执行命令:crontab -e 没有这个命令下载就好了。
执行上面命令后,会打开vim编辑,按insert键盘进行编辑,如下:
第一句是每隔10分钟,执行脚本。第二句是写日志。
不一定非要等10分钟,可以先执行mysql_backup.sh脚本,在此脚本所在目录下直接敲回车命令./mysql_backup.sh,成功生成sql脚本表示脚本没问题。
等待十分钟后,查看定时任务是否成功。
需要docker命令的进行数据库备份的也可以留言或联系我。