通过 crontab 运行“docker run”命令不起作用

时间:2021-07-23 15:13:03

标签: docker ubuntu server cron

每分钟(用于测试)我正在运行一个 cronjob 来创建一个容器,在其中运行一个 nodejs 进程,然后也删除该容器。

它按常规命令的预期工作,但通过 crontab 运行时无法产生任何结果或输出。

这是我的 crontab

*/1 * * * * sh /location_to_cron/cron.sh >> /location_to_cron/backup.log

这里是cron shell脚本的内容

CONTAINER_NAME="node_backup_repo"

echo "Creating Container to create backup, name: $CONTAINER_NAME"

docker run --name $CONTAINER_NAME -v /location_to_backup_dir:/app --dns="my_custom_dns" -w /app node:16 "backupscript.js" >> /location_to_cron/backup.log

echo "Removing container $CONTAINER_NAME"
docker rm $CONTAINER_NAME

echo "All done..."

Syslog 条目表明 crontab 正在以我的用户身份执行,这符合预期。这里可能有什么问题?

编辑: 修改后的工作脚本 - 修复是添加到 docker 二进制文件的路径

CONTAINER_NAME="node_backup_repo"

echo "Creating Container to do Backup, name: $CONTAINER_NAME"

/snap/bin/docker run --name $CONTAINER_NAME -v /location_to_backup_dir:/app --dns="my_custom_dns" -w /app node:16 "backupscript.js" >> /location_to_cron/backup.log

echo "Removing container $CONTAINER_NAME"
/snap/bin/docker rm $CONTAINER_NAME

echo "All done..."

1 个答案:

答案 0 :(得分:0)

使用这个:

*/1 * * * * sh /location_to_cron/cron.sh >> /location_to_cron/backup.log 2>&1

它可以将 stdoutstderr 发送到 backup.log