我的crontab中有一个如下所示的条目:
0 3 * * * pg_dump mydb | gzip > ~/backup/db/$(date +%Y-%m-%d).psql.gz
当我从shell执行它时,该脚本工作正常,但它似乎并不是每晚都在运行。我假设权限有问题,也许crontab在不同的用户或其他东西下运行。我该怎么调试呢?我是一个共享托管环境(WebFaction)。
答案 0 :(得分:9)
您需要使用反斜杠转义crontab条目中的“%”字符 - 请参阅crontab(5)联机帮助页。我有完全相同的问题。
例如:
0 7 * * * mysqldump usblog | bzip2 -c > usblog.$(date --utc +\%Y-\%m-\%dT\%H-\%M-\%SZ).sql.bz2
你没有收到有关cron错误的电子邮件吗?即使你把“MAILTO = your@example.com”放在crontab中也不行?
如果pg_dump或gzip不在系统默认路径上,您可能还需要在crontab中设置PATH(因此使用“type pg_dump”来检查它们的位置,crontab通常只在/ bin或/ usr /中运行命令bin默认情况下)
答案 1 :(得分:2)
始终在crontab entrties中使用完整路径。例如,/usr/bin/gzip
。您还需要为pg_dump
和date
执行此操作。
答案 2 :(得分:2)
当你说它不起作用时,你的意思是什么?它根本不生成文件还是空的?
如果您的系统设置正确,如果您的命令生成了任何输出,crontab应该会向您发送电子邮件。
尝试使用类似的方法来验证crontab是否正在运行。它会每分钟触摸一次文件。
* * * * * touch /tmp/foo
检查詹姆斯提到的路径。
答案 3 :(得分:1)
如果这与/ etc / crontab类似,请确保包含该用户:
0 3 * * * <user_goes_here> pg_dump mydb | gzip > ~/backup/db/$(date +%Y-%m-%d).psql.gz