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

相关推荐
6***x54533 分钟前
Java设计模式之策略模式
java·设计模式·策略模式
章鱼哥73036 分钟前
Java 策略模式 + 聚合对象:实现多模块的统计与聚合,快速扩展的实战
java·开发语言·策略模式
h***59331 小时前
SpringBoot中如何手动开启事务
java·spring boot·spring
倚肆1 小时前
Java泛型详解:尖括号<>、通配符?与类型参数T
java
韩风6661 小时前
雪花id改多workerID依赖redis
java
BD_Marathon1 小时前
Eclipse 代码自动补全设置
android·java·eclipse
L.EscaRC1 小时前
深入解析SpringBoot中的循环依赖机制与解决方案
java·spring boot·spring·循环依赖
曾经的三心草2 小时前
JavaEE初阶-网络原理1
java·网络·java-ee
一 乐3 小时前
健身达人小程序|基于java+vue健身达人小程序的系统设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序
u***42074 小时前
Ubuntu介绍、与centos的区别、基于VMware安装Ubuntu Server 22.04、配置远程连接、安装jdk+Tomcat
java·ubuntu·centos