解决crontab无法执行docker exec命令问题

解决crontab无法执行docker exec命令问题

1. 问题现象

我想使用docker exec对命令对docker中的 mysql数据库进行备份,然后当我使用crontab添加备份命令

复制代码
*/2 * * * * docker exec -i mysql /bin/bash -c 'mysqldump -uroot -pa123456  --port=3306  testdb' > /home/backup/test_$(date +%Y%m%d%H%M%S).sql

每两分钟执行一次,crontab中一直无法进行备份

单独执行

复制代码
 docker exec -i mysql /bin/bash -c 'mysqldump -uroot -pa123456  --port=3306  testdb' > /home/backup/test_$(date +%Y%m%d%H%M%S).sql

备份命令,备份没有问题。

crontab中不能有-it这种存在,-it会拉起终端,所以去掉之后还是无法执行。最终几经尝试后,终于解决了

2. 解决方法

为什么crontab无法执行docker exec命令呢,因为crontab中无法识别到docker命令,网上搜到说这种方法可以解决,就是直接使用/usr/bin/docker 指定docker,单独执行也是没有问题,但是放crontab依然不行。大家可以自行试试。

复制代码
*/2 * * * * /usr/bin/docker exec mysql /bin/bash -c 'mysqldump -uroot -pa123456  --port=3306  testdb' > /home/backup/test_$(date +%Y%m%d%H%M%S).sql

这里我才用新建一个shell脚本的方式解决了此问题

首先新建一个backupmysql.sh的脚本

然后脚本里首先加载系统环境变量source /etc/profile,然后再执行我的脚本,这样备份命令就能被crontab正常执行了。

但是我又想了,我采用了

复制代码
*/2 * * * * source /etc/profile&&/usr/bin/docker exec mysql /bin/bash -c 'mysqldump -uroot -pa123456  --port=3306  testdb' > /home/backup/test_$(date +%Y%m%d%H%M%S).sql

依然不行,非常奇怪

3. 最终方案

最后采用独立脚本的方式,脚本里首先加载系统变量,这样是能正常定时任务执行docker命令的。

最后贴出来我的备份docker中mysql脚本

复制代码
#!/bin/bash
# auth Eric
source  /etc/profile
# 设置备份目录和文件名
backup_directory="/app/backup"
#测试名字用%Y%m%d%H%M%S正式可以用%Y%m%d
backup_filename="test_$(date +%Y%m%d).sql"

# 设置MySQL连接参数
mysql_host="localhost"
mysql_user="root"
mysql_port="3306"
mysql_password="a12345"
mysql_database="testdb"

# 创建备份目录(如果不存在)
mkdir -p "$backup_directory"

# 执行备份命令
docker exec  mysql /bin/bash -c 'mysqldump -u$mysql_user -p$mysql_password --port=$mysql_port $mysql_database' > $backup_directory/$backup_filename

#删除7天前数据
find $backup_directory -name "test_*.sql" -mtime +7 -exec rm {} \;

# 检查备份是否成功
if [ $? -eq 0 ]; then
  echo "MySQL数据库备份成功:$backup_directory/$backup_filename"
else
  echo "MySQL数据库备份失败"
fi

4. 更多资料

Linux cron定时任务常用方法

Docker容器中的mysql自动备份脚本

相关推荐
七七powerful11 分钟前
K8s 工具安装文档 — Harbor + ArgoCD
容器·kubernetes·argocd
立莹Sir13 分钟前
云原生实战:从零搭建企业级K8s环境
云原生·容器·kubernetes
Mapleay19 分钟前
创建 Linux SDK包源码阅读环境
linux·运维·服务器
hong781720 分钟前
阿里coding plan qwen3.6-plus 不支持图片上下文长度只有200K,问题出在哪?
linux·运维·数据库
Lsir10110_27 分钟前
深入链路层:报文 MAC 传输原理与 ARP 欺骗、中间人攻击全解析
运维·服务器·网络
FelixBitSoul31 分钟前
Docker 镜像 SIZE、DISK USAGE、Layer、Prune、.dockerignore 全面解析:pull 到底下载多少?
docker
modelmd33 分钟前
Docker 重命名数据卷
运维·docker·容器
Skilce35 分钟前
K8S部署
linux·运维·服务器·容器·kubernetes
程序员老邢35 分钟前
【技术底稿 12】内网统一日志系统 Loki + Promtail 全流程部署(对接 Grafana,监控日志一体化)
java·运维·程序人生·grafana·devops
张32336 分钟前
kubernetes Pod难点
云原生·容器·kubernetes