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

相关推荐
karry_k44 分钟前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
karry_k1 小时前
PostgreSQL 在 MyBatis 中执行正常 SQL 失效:一次 DELETE USING 踩坑记录
java·后端
辉的技术笔记5 小时前
Dify 自部署为什么跑不动?6 层瓶颈诊断法教你定位
docker
SamDeepThinking5 小时前
从源码到代码:MyBatis-Flex 与 MyBatis-Plus 的逐项对比
java·后端·程序员
她的男孩7 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
荣码9 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev11 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波19 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing