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

相关推荐
hashiqimiya2 分钟前
springboot事务触发滚动与不滚蛋
java·spring boot·后端
PPPHUANG26 分钟前
一次 CompletableFuture 误用,如何耗尽 IO 线程池并拖垮整个系统
java·后端·代码规范
恩创软件开发34 分钟前
创业日常2026-1-8
java·经验分享·微信小程序·小程序
想用offer打牌1 小时前
一站式了解Spring AI Alibaba的流式输出
java·人工智能·后端
Lonely丶墨轩1 小时前
从登录入口窥见架构:一个企业级双Token认证系统的深度拆解
java·数据库·sql
青州从事5212 小时前
20260108【mac】【brew】【docker】安装
macos·docker·eureka
掘根2 小时前
【仿Muduo库项目】EventLoop模块
java·开发语言
信码由缰2 小时前
Java 中的 AI 与机器学习:TensorFlow、DJL 与企业级 AI
java
沙子迷了蜗牛眼3 小时前
当展示列表使用 URL.createObjectURL 的创建临时图片、视频无法加载问题
java·前端·javascript·vue.js