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

相关推荐
刘若水10 分钟前
Linux: 进程信号初识
linux·运维·服务器
小刘爱喇石( ˝ᗢ̈˝ )28 分钟前
玛卡巴卡的k8s知识点问答题(六)
云原生·容器·kubernetes
rider18931 分钟前
【1】搭建k8s集群系列(二进制部署)之系统初始化
云原生·容器·kubernetes
阳小江1 小时前
Docker知识点
运维·docker·容器
极客柒2 小时前
RustDesk 开源远程桌面软件 (支持多端) + 中继服务器伺服器搭建 ( docker版本 ) 安装教程
服务器·docker·开源
只是橘色仍温柔2 小时前
xshell可以ssh连接,但vscode不行
运维·vscode·ssh
IT里的交易员2 小时前
【系统】换硬盘不换系统,使用WIN PE Ghost镜像给电脑无损扩容换硬盘
运维·电脑
共享家95272 小时前
深入剖析Linux常用命令,助力高效操作
linux·运维·服务器
小刘爱喇石( ˝ᗢ̈˝ )2 小时前
玛卡巴卡的k8s知识点问答题(七)
云原生·容器·kubernetes
大刘讲IT3 小时前
制造业数字化转型:流程改造先行还是系统固化数据?基于以MTO和MTS的投资回报分析
运维·经验分享·生活·产品经理·数据可视化