利用linux系统自带的cron 定时备份数据库,不需要写代码了

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命令的进行数据库备份的也可以留言或联系我。

相关推荐
-Thinker3 分钟前
【无标题】
java·开发语言·算法·图搜索
王五周八6 分钟前
Tesseract OCR的Java使用(附安装包,非常详细)
java·开发语言·ocr
旧书包的青春7 分钟前
2026年6月11日
java
IVEN_11 分钟前
本地正常,Docker 怎么就空白:Next.js SSR 的 Alpine musl DNS 陷阱
前端·docker·next.js
实在智能RPA19 分钟前
航空Agent落地效果评估指标:2026年企业级智能自动化价值度量体系拆解
java·网络·人工智能·ai·自动化
程序员二叉25 分钟前
【JUC】AQS底层深度拆解|独占/共享模式|队列原理全详解
java·开发语言·面试·juc
地铁潜行者30 分钟前
消息堆积后,为什么一扩容消费者,MySQL 先被打崩了?
java·后端
地铁潜行者34 分钟前
订单状态更新成功了,分账消息却没发出去:聊聊本地消息表的一致性坑
java·后端
亦暖筑序34 分钟前
Java 8老系统SQL Agent实战:AI生成候选SQL,安全引擎拦截后再执行
java·人工智能·sql
CodeStats36 分钟前
《源纹天书》卷一:归元初醒(第1-5章)
java