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

相关推荐
一点晖光1 小时前
Docker 作图咒语生成器搭建指南
python·docker
qianshuaiblog.cn2 小时前
Kubernetes安装部署
云原生·容器·kubernetes
夜月yeyue2 小时前
Linux内高端内存
linux·运维·单片机·嵌入式硬件·ci/cd·硬件架构
云宏信息2 小时前
运维效率提升实战:如何用轻量化云管平台统一纳管与自动化日常资源操作
运维·服务器·网络·架构·云计算
XINERTEL2 小时前
自动化测试的「千里眼」:当RTSM远程控制遇上自动化,测试效率直接拉满
运维·功能测试·自动化·以太网测试
杨云龙UP2 小时前
MySQL 自动备份与覆盖恢复实战:一套脚本搞定全库/按库备份恢复
linux·运维·数据库·sql·mysql
sjg200104143 小时前
Deepin 20.9 误装gcc-8-base_8.4.0-1ubuntu1~16.04.1_amd64 后卸载
linux·运维·服务器
一帘忧梦3 小时前
linux 系统rcs脚本启动
linux·运维·lua
jerryinwuhan4 小时前
1210_1 Linux
linux·运维·服务器
福尔摩斯张4 小时前
Linux信号捕捉特性详解:从基础到高级实践(超详细)
linux·运维·服务器·c语言·前端·驱动开发·microsoft