如何测试crontab条目?

mpe*_*pen 3 postgresql shell crontab

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

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

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

ara*_*nid 9

您需要使用反斜杠转义crontab条目中的"%"字符 - 请参阅crontab(5)联机帮助页.我有完全相同的问题.

例如:

0 7 * * * mysqldump usblog | bzip2 -c > usblog.$(date --utc +\%Y-\%m-\%dT\%H-\%M-\%SZ).sql.bz2
Run Code Online (Sandbox Code Playgroud)

你没有收到有关cron错误的电子邮件吗?即使你把"MAILTO = your@example.com"放在crontab中也没有?

如果pg_dump或gzip不在系统默认路径上,您可能还需要在crontab中设置PATH(因此使用"type pg_dump"来检查它们的位置,crontab通常只在/ bin或/ usr/bin中运行命令)