如何测试crontab条目?

时间:2010-06-09 20:39:46

标签: postgresql shell crontab

我的crontab中有一个如下所示的条目:

0 3 * * * pg_dump mydb | gzip > ~/backup/db/$(date +%Y-%m-%d).psql.gz

当我从shell执行它时,该脚本工作正常,但它似乎并不是每晚都在运行。我假设权限有问题,也许crontab在不同的用户或其他东西下运行。我该怎么调试呢?我是一个共享托管环境(WebFaction)。

4 个答案:

答案 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_dumpdate执行此操作。

答案 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