解决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自动备份脚本

相关推荐
峥无18 分钟前
Linux系统编程基石:静态库·动态库·ELF文件·进程地址空间全景图
linux·运维·服务器
码云数智-大飞32 分钟前
本地部署大模型:隐私安全与多元优势一站式解读
运维·网络·人工智能
Harvy_没救了2 小时前
【网络部署】 Win11 + VMware CentOS8 + Nginx 文件共享服务 Wiki
运维·网络·nginx
春风有信2 小时前
【2026.05.01】Windows10安装Docker Desktop 4.71.0.0步骤及问题解决
运维·docker·容器
2401_873479403 小时前
断网时如何实时判断IP归属?嵌入本地离线库,保障风控不中断
运维·服务器·网络
守城小轩3 小时前
基于Chrome140的Yahoo自动化(关键词浏览)——需求分析&环境搭建(一)
运维·自动化·chrome devtools·浏览器自动化·指纹浏览器·浏览器开发
handler013 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
日取其半万世不竭5 小时前
LVM 逻辑卷管理:不停机扩容磁盘的正确方式
运维·服务器
优化Henry5 小时前
TDD-LTE站点Rilink=3链路故障处理案例---BBU侧C口“有发光、无收光”的排查与恢复
运维·网络·信息与通信·tdd
浪客灿心5 小时前
Linux网络传输层协议
linux·运维·网络