我尝试从docker容器内运行的postgresql数据库进行自动化(每晚4点)备份.
#!/bin/sh
CONTAINER=`docker ps|grep name_of_container|awk '{print $1}'`
USER='postgre_user'
PASSWORD='changed'
BUDIR='/some/path/backup/'
docker run -it --link $CONTAINER:db -v $BUDIR:/backup/ -e "PGPASSWORD=$PASSWORD" pg_dump -h db -U $USER -Fc -f /backup/$(date +%Y-%m-%d-%H-%M-%S).dump
我的crontab看起来像这样:
0 4 * * * /path/to/script.sh
当我手动执行它时脚本工作正常,它也从cron执行(我试过* * * * *进行调试).
我无法弄清楚如何让cron和脚本一起工作.到目前为止我试过:
>将变量写入日志文件
>检查来自crontab的输出(* * * * * […]&> cron.log)
>检查来自docker exec […]>的输出脚本中的output.log
从cron运行时,$CONTAINER包含正确的docker id,cron.log和output.log已创建但为空.
有任何想法吗?
最佳答案
从cron运行时无法使用docker run -it –link […] – 我现在使用docker run –link […].
原文链接:https://www.f2er.com/docker/435816.html