解决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